搜索二维矩阵 II(java)

题目描述

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

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

代码思路:

用暴力算法:

java 复制代码
class Solution {
    public boolean searchMatrix(int[][] matrix, int target) {
        // boolean flag = false;
        if(matrix==null ||matrix.length==0 ||target<matrix[0][0]){
            return false;
        }
        int n=matrix.length;
        int m=matrix[0].length;
       
        for(int i=0;i<n;i++){
            for(int j=0;j<m;j++){
                if(matrix[i][j]==target){
                    return true;
                }else if(matrix[i][j]>target){
                    break;
                }
            }
        }
        return false;
    }
}

巧妙的方法:

这个把他看做一个二叉搜索树,其中右上角点是根节点,往下是右子树,往左是左子树。复杂度O(log(M*N))

java 复制代码
class Solution {
    public boolean searchMatrix(int[][] matrix, int target) {
        if(matrix==null ||matrix.length==0 ||target<matrix[0][0]){
            return false;
        }
        int n=matrix.length;
        int m=matrix[0].length;
        int i = 0;
        int j = m-1;
        while(true){
            if(matrix[i][j]==target){
                return true;
            }else if(matrix[i][j]>target){
                j--;
                if(j<0){
                    return false; 
                }
            }else{
                i++;
                if(i>n-1){
                    return false;
                }
            }
        }
        
    }
}
相关推荐
程序员-King.10 分钟前
day86——有效的字母异位词(LeetCode-242)
算法·字符串
xxxxxxllllllshi34 分钟前
Java 代理模式深度解析:从静态到动态,从原理到实战
java·开发语言·笔记·算法·代理模式
冷yan~43 分钟前
Spring AI与智能代理模式的深度解析
java·spring·ai·ai编程
天航星44 分钟前
Docker 安装 Jenkins
java·运维·jenkins
步行cgn1 小时前
SqlSessionFactory 的作用
java·开发语言
Starry_hello world1 小时前
C++ 二分算法(1)
c++·算法·有问必答
代码匠心1 小时前
从零开始学Flink:实时流处理实战
java·大数据·后端·flink
爱隐身的官人2 小时前
JAVA代码审计总结
java·网络·安全
小杨勇敢飞2 小时前
拼图小游戏开发日记 | Day3(已完结)
java·数据结构·算法
Guan jie2 小时前
10.6作业
数据结构·算法·排序算法