力扣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;
    }
};
相关推荐
凌波粒19 小时前
LeetCode--二叉树层序遍历实战指南
算法·leetcode·职场和发展
洛水水19 小时前
【力扣100题】48.乘积最大子数组
算法·leetcode·职场和发展
小小de风呀19 小时前
de风——【从零开始学C++】(七):string类详解
开发语言·c++·算法
YL2004042619 小时前
042将有序数组转换为二叉搜索树
数据结构·算法·leetcode
qq_2965532719 小时前
矩阵对角线遍历:从暴力到最优的优雅解法
数据结构·线性代数·算法·青少年编程·矩阵·深度优先遍历
洛水水19 小时前
【力扣100题】50.最长有效括号
算法·leetcode·职场和发展
数智工坊19 小时前
【BLIP论文阅读】:统一视觉语言理解与生成的自举式预训练范式
论文阅读·人工智能·深度学习·算法·transformer
yyy(十一月限定版)19 小时前
问题解决策略搜索训练3
算法
吃好睡好便好19 小时前
在Matlab中绘制圆锥三维曲面图
开发语言·人工智能·学习·算法·matlab·信息可视化
兰令水19 小时前
topcode【随机算法题】【2026.5.15打卡-java版本】
java·算法·leetcode