二分查找-搜索二维矩阵

74.搜索二维矩阵

java 复制代码
给你一个满足下述两条属性的 m x n 整数矩阵:

每行中的整数从左到右按非严格递增顺序排列。
每行的第一个整数大于前一行的最后一个整数。
给你一个整数 target ,如果 target 在矩阵中,返回 true ;否则,返回 false 。

输入 :二维数组,目标值
输出 :布尔
思路 :一次二分查找,将二维数组看成是一个一维数组,然后进行二分查找

细节实现:

二分查找的头为0,尾为数组的元素个数,中间值使用matrix[mid/n][mid%n]

java 复制代码
class Solution {
    public boolean searchMatrix(int[][] matrix, int target) {
        int m = matrix.length;
        int n = matrix[0].length;
        int left = 0;
        int right = m * n - 1;
        while(left <= right){
            int mid = (left + right) / 2;
            int x = matrix[mid / n][mid % n];
            if(x < target){
                left = mid + 1;
            }else if(x > target){
                right = mid - 1;
            }else{
                return true;
            }
        }
        return false;
    }
}

注意在while循环中left <= right

相关推荐
冬夜戏雪9 分钟前
实习面经记录(十)
java·前端·javascript
skiy17 分钟前
java与mysql连接 使用mysql-connector-java连接msql
java·开发语言·mysql
bulingg21 分钟前
L1与L2正则化的差异
线性代数·矩阵·概率论
平生不喜凡桃李29 分钟前
浅谈 Linux 中 namespace 相关系统调用
java·linux·服务器
zb2006412035 分钟前
CVE-2024-38819:Spring 框架路径遍历 PoC 漏洞复现
java·后端·spring
2401_895521341 小时前
spring-ai 下载不了依赖spring-ai-openai-spring-boot-starter
java·人工智能·spring
何仙鸟1 小时前
GarmageSet下载和处理
java·开发语言
wefly20171 小时前
免安装!m3u8live.cn在线 M3U8 播放器,小白也能快速上手
java·开发语言·python·json·php·m3u8·m3u8在线转换
yuweiade1 小时前
springboot和springframework版本依赖关系
java·spring boot·后端
ywf12151 小时前
springboot设置多环境配置文件
java·spring boot·后端