Leetcode面试经典150题-74.搜索二维矩阵

解法都在代码里,不懂就留言或者私信

二分查找,比较简单

java 复制代码
class Solution {
    /**解题思路:每一行有序、每一列也有序,只是整体不是严格有序的,那我们需要找一个点,只能往两个方向走,往一个方向走是变小
    往另外一个方向走是变大,我们右两种选择:左下角的点和右上角的点
    我习惯于用右上角的点 */
    public boolean searchMatrix(int[][] matrix, int target) {
        /**就一个数比较相等不相等就完事了呗 */
        if(matrix.length == 1 && matrix[0].length == 1) {
            return matrix[0][0] == target;
        }
        int curRow = 0;
        int curCol = matrix[0].length - 1;
        /**行是变大的,列是变小的,只有这一种走法,while条件是为了避免越界*/
        while(curRow < matrix.length && curCol >= 0) {
            if(matrix[curRow][curCol] == target) {
                return true;
            } else if(matrix[curRow][curCol] < target) {
                curRow ++;
            } else {
                curCol --;
            }
        }
        /**中间没有返回true说明没找到,这里返回false作为答案 */
        return false;
    }
}
相关推荐
t***44232 小时前
【Springboot3+vue3】从零到一搭建Springboot3+vue3前后端分离项目之后端环境搭建
java
daidaidaiyu2 小时前
SpringCloud 微服务实现一则 (Eureka + Hystrix)
java·spring
plus4s2 小时前
2月12日(70-72题)
算法
小哥不太逍遥2 小时前
Technical Report 2024
java·服务器·前端
m0_672703313 小时前
上机练习第24天
算法
edisao3 小时前
序幕-内部审计备忘录
java·jvm·算法
shehuiyuelaiyuehao3 小时前
22Java对象的比较
java·python·算法
常利兵4 小时前
吃透Java操作符高阶:位操作符+赋值操作符全解析(Java&C区别+实战技巧+面试考点)
java·c语言·面试
不用89k4 小时前
SpringBoot学习新手项初识请求
java·spring boot·学习
码农阿豪4 小时前
SpringBoot实现公正有趣好玩的年会抽奖系统
java·spring boot·后端