【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;
    }
相关推荐
你撅嘴真丑5 小时前
第九章-数字三角形
算法
uesowys5 小时前
Apache Spark算法开发指导-One-vs-Rest classifier
人工智能·算法·spark
ValhallaCoder5 小时前
hot100-二叉树I
数据结构·python·算法·二叉树
董董灿是个攻城狮5 小时前
AI 视觉连载1:像素
算法
智驱力人工智能6 小时前
小区高空抛物AI实时预警方案 筑牢社区头顶安全的实践 高空抛物检测 高空抛物监控安装教程 高空抛物误报率优化方案 高空抛物监控案例分享
人工智能·深度学习·opencv·算法·安全·yolo·边缘计算
孞㐑¥7 小时前
算法——BFS
开发语言·c++·经验分享·笔记·算法
月挽清风7 小时前
代码随想录第十五天
数据结构·算法·leetcode
XX風7 小时前
8.1 PFH&&FPFH
图像处理·算法
NEXT067 小时前
前端算法:从 O(n²) 到 O(n),列表转树的极致优化
前端·数据结构·算法
代码游侠8 小时前
学习笔记——设备树基础
linux·运维·开发语言·单片机·算法