力扣240 搜索二维矩阵 ll

编写一个高效的算法来搜索 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

示例 2:

复制代码
输入: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 = 20
输出:false

解法:从右上角看本质是一个二叉搜索树,左边比自己小,下面比自己大,因此从右上角开始搜索,如果当前值比的target大,那就列左移,否则行下移

java 复制代码
class Solution {
    public boolean searchMatrix(int[][] matrix, int target) {
        if(matrix.length == 0){
         return false;
        }
        int row = 0;
        int col = matrix[0].length - 1;
        while(row < matrix.length && col >= 0){
            if(matrix[row][col] == target){
                return true;
            }else if(matrix[row][col] > target){
                col--;
            }else {
                row++;
            }
        }
        return false;
    }
}
相关推荐
王守乐3 小时前
搜索+图论1 练习答案+思路
算法·深度优先
CS创新实验室4 小时前
《机器学习数学基础》补充资料:矩阵基本子空间
人工智能·机器学习·矩阵
IT猿手5 小时前
离散浣熊优化算法(DCOA)求解大规模旅行商问题(Large-Scale Traveling Salesman Problem,LTSP),MATLAB代码
开发语言·深度学习·算法·机器学习·matlab
查理零世6 小时前
【算法】动态规划专题⑥ —— 完全背包问题 python
python·算法·动态规划
澄岚明雪8 小时前
力扣经典题目之14. 最长公共前缀
算法·leetcode·职场和发展
muxue1788 小时前
python:递归函数与lambda函数
开发语言·python·算法
終不似少年遊*8 小时前
排序算法3
python·算法·排序算法
qy发大财8 小时前
组合(力扣77)
数据结构·算法·leetcode·职场和发展
源代码•宸9 小时前
Leetcode—734. 句子相似性【简单】Plus
c++·经验分享·算法·leetcode·哈希算法