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;
        
    }


}
相关推荐
思绪漂移32 分钟前
同源“平滑思想”的问题解法:正则化与拉普拉斯平滑
人工智能·算法
想睡hhh1 小时前
Practice 2025.5.29 —— 二叉树进阶面试题(1)
c++·算法
vvilkim1 小时前
C# 数组与字符串:全面解析与应用实践
开发语言·算法·c#
南枝异客2 小时前
力扣-最长回文子串
算法·leetcode·职场和发展
pen-ai2 小时前
【深度学习-pytorch篇】1. Pytorch矩阵操作与DataSet创建
pytorch·深度学习·矩阵
橙留香mostarrain2 小时前
从零开始的数据结构教程(四) 图论基础与算法实战
数据结构·算法·图论
xy_optics3 小时前
Wirtinger Flow算法的matlab实现和python实现
python·算法·matlab
zyq~3 小时前
【课堂笔记】EM算法
人工智能·笔记·算法·机器学习·概率论·gmm·em算法
Giser探索家4 小时前
「卫星百科」“绿色守卫”高分六号
大数据·人工智能·数码相机·算法·分类·云计算