【LeetCode热题100】--240.搜索二维矩阵II

240.搜索二维矩阵II

编写一个高效的算法来搜索 m x n 矩阵 matrix 中的一个目标值 target 。该矩阵具有以下特性:

  • 每行的元素从左到右升序排列。
  • 每列的元素从上到下升序排列。

方法一:使用二分查找

java 复制代码
class Solution {
    public boolean searchMatrix(int[][] matrix, int target) {
        for(int[] row : matrix){  //按行查找
            int index = search(row,target);
            if(index >= 0){
                return true;
            }
        }
        return false;
        
    }
    //使用二分查找
    public int search(int[] nums,int target){
        int low = 0,high = nums.length -1;
        while(low <= high){
            int mid = (high - low) / 2 + low;
            int num = nums[mid];
            if(num == target){
                return mid;
            }else if(num > target){
                high = mid -1;
            }else{
                low = mid + 1;
            }
        }
        return -1;
    }
}

方法二:Z字形查找

从矩阵的右上角(0,n-1)进行搜索,在每一步的搜索过程中,如果我们位于位置(x,y),那么就希望在矩阵的左下角为左下角,以(x,y)为右上角的矩阵中进行搜索,即行的范围为[x,m-1],列的范围为[0,y]

  • 如果 m a t r i x [ x , y ] = t a r g e t matrix[x,y]=target matrix[x,y]=target,说明搜索完成
  • 如果 m a t r i x [ x , y ] > t a r g e t matrix[x,y]>target matrix[x,y]>target,由于每一列的元素都是升序排列的,那么在当前的搜索矩阵中,所有位于第y列的元素都是严格大于target的,因此将其全部忽略,即将y-1
  • 如果 m a t r i x [ x , y ] < t a r g e t matrix[x,y]<target matrix[x,y]<target,由于每一行的元素都是升序排列的,那么在当前的搜索矩阵中,所有位于第x行的元素都是严格小于target的,因此可以将其全部忽略,即x+1
java 复制代码
class Solution {
    public boolean searchMatrix(int[][] matrix, int target) {
        int m = matrix.length,n = matrix[0].length;
        int x = 0,y = n-1;
        while(x < m && y >= 0){
            if(matrix[x][y] == target){
                return true;
            }
            if(matrix[x][y] > target){
                --y;
            }else{
                ++x;
            }
        }
        return false;
    }
}
相关推荐
listhi5203 小时前
基于改进SET的时频分析MATLAB实现
开发语言·算法·matlab
Keep_Trying_Go4 小时前
基于Zero-Shot的目标计数算法详解(Open-world Text-specified Object Counting)
人工智能·pytorch·python·算法·多模态·目标统计
xl.liu4 小时前
零售行业仓库商品数据标记
算法·零售
confiself4 小时前
通义灵码分析ms-swift框架中CHORD算法实现
开发语言·算法·swift
做怪小疯子4 小时前
LeetCode 热题 100——二叉树——二叉树的层序遍历&将有序数组转换为二叉搜索树
算法·leetcode·职场和发展
CoderYanger4 小时前
递归、搜索与回溯-记忆化搜索:38.最长递增子序列
java·算法·leetcode·1024程序员节
xlq223226 小时前
22.多态(下)
开发语言·c++·算法
CoderYanger6 小时前
C.滑动窗口-越短越合法/求最长/最大——2958. 最多 K 个重复元素的最长子数组
java·数据结构·算法·leetcode·哈希算法·1024程序员节
却话巴山夜雨时i6 小时前
394. 字符串解码【中等】
java·数据结构·算法·leetcode
haing20197 小时前
使用黄金分割法计算Bezier曲线曲率极值的方法介绍
算法·黄金分割