【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;
    }
相关推荐
Allen Wurlitzer36 分钟前
算法刷题记录——LeetCode篇(8.7) [第761~770题](持续更新)
算法·leetcode·职场和发展
悄悄敲敲敲1 小时前
C++第13届蓝桥杯省b组习题笔记
c++·笔记·算法·蓝桥杯
_殊途1 小时前
算法--滑动窗口
算法
kkk16222451 小时前
matlab有限元求转子临界转速
算法
啥都鼓捣的小yao2 小时前
Python使用SVC算法解决乳腺癌数据集分类问题——寻找最佳核函数
python·算法·分类
Java版蜡笔小新3 小时前
算法-贪心算法
算法·贪心算法
LuckyAnJo4 小时前
Leetcode-100 回溯法-电话号码的字母组合
python·算法·leetcode
HR Zhou4 小时前
群体智能优化算法-鹈鹕优化算法(Pelican Optimization Algorithm, POA,含Matlab源代码)
算法·机器学习·matlab·优化·群体智能优化
LuckyLay4 小时前
LeetCode算法题(Go语言实现)_20
算法·leetcode·职场和发展·golang
Phoebe鑫5 小时前
数据结构每日一题day7(顺序表)★★★★★
算法