day12 leetcode-hot100-21(矩阵4)

240. 搜索二维矩阵 II - 力扣(LeetCode)

1.暴力法O(m*n)

思路:两层for循环即可。

2.二分查找O(m*logn)

思路:每行都用二分查找,因为每行都是排好序的

java 复制代码
class Solution {
    public boolean searchMatrix(int[][] matrix, int target) {
        for(int[] row : matrix){
            if(search_t(row,target)){
                return true;
            }

        }
        return false;
        
    }

    public boolean search_t(int[] nums,int t){
        int l=0;
        int r=nums.length-1;
        

        while(l<=r){
            int mid=(r-l)/2+l;
            if(nums[mid]==t){
                return true;
            }
            if(nums[mid]>t){
                r=mid-1;
            }
            if(nums[mid]<t){
                l=mid+1;
            }
        }
        return false;
    }


}

3.Z字搜索

思路

因为每行都是递增的,每列也是递增的,所以我们可以选择从右上角开始遍历,遇到大于target的那就向左走,遇到小于target那就向下走。

具体代码
java 复制代码
class Solution {
    public boolean searchMatrix(int[][] matrix, int target) {
        int n=matrix[0].length;
        int x=0;
        int y=n-1;

        while(x<=matrix.length-1 && y>=0){
            if(matrix[x][y]==target){
                return true;
            }
            if(matrix[x][y]>target){
                y--;
            }
            else{
                x++;
            }
        }
        return false;
        
    }


}
相关推荐
EdmundXjs41 分钟前
大模型核心概念解读
人工智能·算法
lookaroundd43 分钟前
llm-compressor 普通量化调用链分析
python·算法
小羊在睡觉1 小时前
力扣239. 滑动窗口最大值
数据结构·后端·算法·leetcode·go
兰令水1 小时前
topcode【随机算法题】【2026.5.20打卡-java版本】
java·开发语言·算法
此生决int1 小时前
算法从入门到精通——前缀和
c++·算法·蓝桥杯
大大杰哥1 小时前
leetcode hot100(4)矩阵
算法·leetcode·矩阵
小白|2 小时前
cmake:昇腾CANN构建系统完全指南
java·c++·算法
nebula-AI2 小时前
人工智能导论:模型与算法(未来发展与趋势)
人工智能·神经网络·算法·机器学习·量子计算·automl·类脑计算
炽烈小老头2 小时前
【每天学习一点算法 2026/05/21】课程表
学习·算法
luoganttcc2 小时前
大模型是否即将到达算法极限
算法