【LC】240. 搜索二维矩阵 II

题目描述:

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

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

示例 1:

复制代码
输入:matrix = [[1,4,7,11,15],[2,5,8,12,19],[3,6,9,16,22],[10,13,14,17,24],[18,21,23,26,30]], target = 5
输出:true

题解:

复制代码
class Solution {
    public boolean searchMatrix(int[][] matrix, int target) {
        for (int[] row : matrix) {
            boolean isMatch = search(row, target);
            if (isMatch) {
                return true;
            }
        }
        return false;
    }

    private boolean search(int[] nums, int target) {
        int n = nums.length;
        int left = 0, right = n - 1;
        while (left <= right) {
            int mid = left + (right - left >> 1);
            if (nums[mid] == target) {
                return true;
            } else if (nums[mid] < target) {
                left = mid + 1;
            } else {
                right = mid - 1;
            }
        }
        return false;
    }
}
相关推荐
2501_916766544 分钟前
【Java】HashMap集合实现类
java·开发语言
hope_wisdom7 分钟前
C/C++数据结构之队列基础
c语言·数据结构·c++·队列·queue
不会聊天真君6479 分钟前
设计模式、线程状态、上下文切换、线程安全(JAVA并发第二期)
java
Swift社区11 分钟前
死锁:线程卡死不是偶然,而是设计问题
java·spring·maven
不一样的故事12611 分钟前
高速采集箱
算法·信号处理
uup11 分钟前
防止短信验证码接口被盗刷问题
java
xxxmine18 分钟前
ConcurrentHashMap 和 Hashtable 的区别详解
java·开发语言
凛_Lin~~18 分钟前
安卓 面试八股文整理(原理与性能篇)
android·java·面试·安卓
weixin_4365250729 分钟前
NestJS-TypeORM QueryBuilder 常用 SQL 写法
java·数据库·sql
oioihoii31 分钟前
C++虚函数表与多重继承内存布局深度剖析
java·jvm·c++