力扣hot100(21)搜索二维矩阵 II

方法:Z字形查找法、二分法、暴力法

面试最优 Z字形查找法:

核心思想:选对起点,一次排除一行或者一列。

找一个特殊的起点,使得每次比较之后,都能直接排除一整行或者一整列。不用遍历多余的元素。

注意不能选择左上角和右下角,因为左上角是最小的元素,如果target比他大,右边和下边的元素都可能更大,没法排除一行或者一列。右下角最大的元素同理。

可以选右上角和左下角,

右上角的元素matrix[x][y],是当前行最大的元素 ,也是当前列最小的元素

  • 如果matrix[x][y] == target:直接找到,返回 true;
  • 如果matrix[x][y] > target:说明这一列所有元素都比target大(因为列是升序的),直接排除这一列,y--
  • 如果matrix[x][y] < target:说明这一行所有元素都比target小(因为行是升序的),直接排除这一行,x++
cpp 复制代码
class Solution {
public:
    bool searchMatrix(vector<vector<int>>& matrix, int target) {
        
       //Z字法:找右上角的元素 来排除一行或者一列 排出后 新的矩阵继续。
    int m =matrix.size();
    int n = matrix[0].size();
    int x=0,y = n-1;
    while(x<m && y>=0){

        if(matrix[x][y] == target){
            return true;
        }

        if(matrix[x][y]<target){
            ++x;
        }

        else{
            --y;
        }
    }
    return false;
    }
};
相关推荐
踩坑记录2 小时前
leetcode 70. 爬楼梯 easy 动态规划 斐波那契数列
leetcode·动态规划
️是782 小时前
信息奥赛一本通—编程启蒙(3380:练65.3 螺旋矩阵)
线性代数·算法·矩阵
天若有情6732 小时前
C++进阶:普通重载运算符 vs 隐式类型转换重载运算符,一篇讲透区别
开发语言·c++·算法
笨蛋不要掉眼泪2 小时前
面试篇-java基础下
java·后端·面试·职场和发展
踩坑记录2 小时前
leetcode hot100 215. 数组中的第K个最大元素 medium 堆 快速选择 pivot分区
leetcode
c++圈来了个新人2 小时前
C++类和对象(中)
c语言·开发语言·数据结构·c++·考研·算法
xin_nai2 小时前
LeetCode热题100 (Java)(1)哈希
算法·leetcode·哈希算法
王老师青少年编程2 小时前
csp信奥赛C++高频考点专项训练之贪心算法 --【删数问题】:删数问题2
c++·算法·贪心·csp·信奥赛
hanbr2 小时前
Leetcode刷题总结(1)
算法·leetcode·职场和发展