【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;
    }
}
相关推荐
Coder_Boy_几秒前
前端和后端软件系统联调经典问题汇总
java·前端·驱动开发·微服务·状态模式
一招定胜负2 分钟前
决策树开篇
算法·决策树·机器学习
GoWjw3 分钟前
C语言高级特性
c语言·开发语言·算法
carver w6 分钟前
说人话版 K-means 解析
算法·机器学习·kmeans
雨中飘荡的记忆11 分钟前
Retrofit:优雅的JAVA网络请求框架实战
java
小O的算法实验室12 分钟前
2026年SEVC SCI2区,基于差分向量内学习策略的自适应指数交叉差分进化算法,深度解析+性能实测
算法·论文复现·智能算法·智能算法改进
Thexhy13 分钟前
基础篇:Redis核心命令及用法
java·linux·redis
狂奔小菜鸡14 分钟前
Day33 | Java中的Optional
java·后端·java ee
啃火龙果的兔子14 分钟前
IntelliJ IDEA社区版下载安装
java·ide·intellij-idea
ckm紫韵19 分钟前
Cursor 与 IDEA 互相跳转教程
java·ide·intellij-idea·cursor·ai工具