leetcode 240. 搜索二维矩阵 II

2023.11.22

本题最先想到的是暴力法和二分法,暴力法就不写了,写一下二分法的解法,java代码如下:

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

翻看了下评论区,有个Z字型解法,是从右上角开始遍历,我则从左下角开始遍历,然后当前元素大于target值就往上走,小于target值就往右走,直到走到边界也没找到就返回false,java代码如下:

java 复制代码
class Solution {
    public boolean searchMatrix(int[][] matrix, int target) {
        int row = matrix.length-1;
        int col = 0;
        //从左下角开始搜索
        while(row>=0 && col<matrix[0].length){
            if(matrix[row][col] == target) return true;
            else if(matrix[row][col] > target) row--;
            else col++;
        }
        return false;
    }
}
相关推荐
Arva .11 分钟前
讲一下 Spring 中用到的设计模式
java·spring·设计模式
bbq粉刷匠20 分钟前
Java-顺序表
java
小白程序员成长日记24 分钟前
2025.12.03 力扣每日一题
算法·leetcode·职场和发展
元亓亓亓28 分钟前
LeetCode热题100--20. 有效的括号--简单
linux·算法·leetcode
熊猫_豆豆34 分钟前
LeetCode 49.字母异位组合 C++解法
数据结构·算法·leetcode
Tan_Ying_Y1 小时前
Mybatis的mapper文件中#和$的区别
java·tomcat·mybatis
难以触及的高度1 小时前
Java for循环完全指南:从基础到高性能实践
java·开发语言
sheji34161 小时前
【开题答辩全过程】以 农产品销售系统为例,包含答辩的问题和答案
java·eclipse
budingxiaomoli1 小时前
多线程(三)
java·开发语言
klzdwydz1 小时前
注解与反射
java·开发语言