【力扣hot100题】(020)搜索二维矩阵Ⅱ

一开始以为一行的末尾小于下一行的开头,于是傻傻的写了两二分查找,所幸的是发现了自己在二分查找上确实不怎么熟练,巩固了一下知识。

这是一开始写的错误答案:

cpp 复制代码
class Solution {
public:
    bool searchMatrix(vector<vector<int>>& matrix, int target) {
        int left=0;
        int right=matrix[0].size()-1;
        int record=0;
        while(left<=right){
            int middle=left+(right-left)/2;
            if(matrix[0][middle]>target) right=middle-1;
            else if(matrix[0][middle]<target) {record=left;left=middle+1;}
            else return 1;
        }
        left=0;
        right=matrix.size()-1;
        while(left+1<right){
            int middle=(left+right+1)/2;
            if(matrix[middle][record]>target) right=middle;
            else if(matrix[middle][record]<target) left=middle;
            else return 1;
        }
        if(matrix[left][record]==target||matrix[right][record]==target) return 1;
        return 0;
    }
};

记起来了二分查找中left和right不能只是等于mid,而是要在mid的基础上加或减,不然会死循环,并且跳出while的条件不能包含left==right,两者相等的情况下还要继续二分。

看答案学到了二分查找的逃课快速实现法:

cpp 复制代码
class Solution {
public:
    bool searchMatrix(vector<vector<int>>& matrix, int target) {
        for(auto& row:matrix){
            auto it=lower_bound(row.begin(),row.end(),target);
            if(it!=row.end()&&*it==target) return 1;
        }
        return 0;
    }
};

lower_bound是一个二分查找的逃课函数,传入始末向量和target,就可以二分搜寻出最接近target的不小于target的元素,如果没有将返回end()。

答案还有一种很天才的思路:z字型查找,从右上开始搜索,如果比target小就删除最上行,比target大就删除最右行,非常高效。

cpp 复制代码
class Solution {
public:
    bool searchMatrix(vector<vector<int>>& matrix, int target) {
        int n=matrix.size();
        int m=matrix[0].size();
        int x=0;
        int y=m-1;
        while(x<n&&y>=0){
            if(matrix[x][y]>target) y--;
            else if(matrix[x][y]<target) x++;
            else return 1;
        }
        return 0;
    }
};
相关推荐
向阳而生,一路生花2 分钟前
深入浅出 JDK7 HashMap 源码分析
算法·哈希算法
君义_noip26 分钟前
信息学奥赛一本通 4150:【GESP2509七级】⾦币收集 | 洛谷 P14078 [GESP202509 七级] 金币收集
c++·算法·gesp·信息学奥赛·csp-s
摸个小yu35 分钟前
【力扣LeetCode热题h100】链表、二叉树
算法·leetcode·链表
汀、人工智能41 分钟前
[特殊字符] 第93课:太平洋大西洋水流问题
数据结构·算法·数据库架构·图论·bfs·太平洋大西洋水流问题
ZPC82101 小时前
rviz2 仿真控制器与真实机器人切换
人工智能·算法·机器人
澈2071 小时前
双指针,数组去重
c++·算法
小辉同志1 小时前
207. 课程表
c++·算法·力扣·图论
CheerWWW1 小时前
深入理解计算机系统——位运算、树状数组
笔记·学习·算法·计算机系统
仟濹2 小时前
2026-04-09~10-复习计划+蓝桥杯注意的点
职场和发展·蓝桥杯
锅挤2 小时前
数据结构复习(第一章):绪论
数据结构·算法