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


}
相关推荐
烨然若神人~4 分钟前
算法第38天|322.零钱兑换\139. 单词拆分
算法
sukalot44 分钟前
window显示驱动开发—输出合并器阶段
驱动开发·算法
fei_sun1 小时前
【编译原理】语句的翻译
算法
Xの哲學1 小时前
hostapd 驱动注册机制深度分析
linux·网络·算法·wireless
int型码农2 小时前
数据结构第八章(六)-置换选择排序和最佳归并树
java·c语言·数据结构·算法·排序算法
@我漫长的孤独流浪2 小时前
数据结构----排序(3)
数据结构·c++·算法
依然易冷3 小时前
【APR-自动代码修复】论文分享:PyTy
算法
ggdpzhk3 小时前
输入两个正整数,计算最大公约数和最小公倍数
java·算法
weixin_307779135 小时前
波动方程兼容性条件分析
算法
-qOVOp-5 小时前
408第二季 - 组成原理 - 流水线
数据结构·算法