【hot100】240搜索二维矩阵

一、思路

总体就是考搜索算法,采用了二分查找进行优化

二、记忆

二分查找的应用思路及写法,在二维举证中对每行应用二分查找即可,不用同时再考虑列

三、代码

3.1直接遍历

复制代码
public boolean searchMatrix(int[][] matrix,int target){
        for(int i = 0;i<matrix.length;i++){
            for(int j = 0;j<matrix[0].length;j++){
                if (matrix[i][j]==target) return true;
            }
        }
        return false;
    }

3.2行二分查找

需要注意的是要一直查找到左右指针错位再停止,相等时也要判断

复制代码
 public boolean searchMatrix(int[][] matrix,int target){
        for(int i = 0;i<matrix.length;i++){
            int index = search(matrix[i],target);
            if (index>=0){
                return true;
            }
        }
        return false;
    }

    private int search(int[] nums,int target){
        int left=0,right = nums.length-1;//注意右指针要长度-1
        while(left<=right){
            int mid = (right-left)/2 + left;
            int num = nums[mid];
            if (num ==target) return mid;
            else if (target<num){
                right = mid-1;
            }else {
                left = mid +1;
            }
        }
        return -1;
    }
相关推荐
hh随便起个名2 小时前
力扣二叉树的三种遍历
javascript·数据结构·算法·leetcode
Dingdangcat863 小时前
城市交通多目标检测系统:YOLO11-MAN-FasterCGLU算法优化与实战应用_3
算法·目标检测·目标跟踪
tang&4 小时前
滑动窗口:双指针的优雅舞步,征服连续区间问题的利器
数据结构·算法·哈希算法·滑动窗口
拼命鼠鼠4 小时前
【算法】矩阵链乘法的动态规划算法
算法·矩阵·动态规划
LYFlied4 小时前
【每日算法】LeetCode 17. 电话号码的字母组合
前端·算法·leetcode·面试·职场和发展
式5164 小时前
线性代数(八)非齐次方程组的解的结构
线性代数·算法·机器学习
橘颂TA5 小时前
【剑斩OFFER】算法的暴力美学——翻转对
算法·排序算法·结构与算法
叠叠乐5 小时前
robot_state_publisher 参数
java·前端·算法
hweiyu005 小时前
排序算法:冒泡排序
算法·排序算法
brave and determined6 小时前
CANN训练营 学习(day9)昇腾AscendC算子开发实战:从零到性能冠军
人工智能·算法·机器学习·ai·开发环境·算子开发·昇腾ai