蓝桥与力扣刷题(240 搜索二维矩阵||)

题目:编写一个高效的算法来搜索 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
输出:fals

解题思路+代码:

代码:

java 复制代码
class Solution {
    public boolean searchMatrix(int[][] matrix, int target) {
        /*
        思路:
        1.判断矩阵是否为空,为空直接返回false
        2.设定目标值在矩阵中进行搜索,搜索到后返回true,反之返回false
        3.选择从右上角开始搜索目标值(利用的是二分查找法)
        */
        if(matrix == null || matrix.length == 0 || matrix[0].length == 0){
            return false;
        }

        int rows = matrix.length;
        int cols = matrix[0].length;

        // 从右上角开始搜索
        int i = 0; // 初始化行指针
        int j = cols - 1; // 初始化列指针
        
        while(i < rows && j >= 0){
            if(matrix[i][j] == target){
                return true;
            }else if(matrix[i][j] > target){
                j--; // 当前值大于目标值,向左移动
            }else{
                i++; // 当前值小于目标值,向下移动
            }
        }

        return false;
    }
}

总结:解决这道题首先要理解题给的是有序矩阵,而我们要做的是在矩阵中快速地找到该目标值。说到查找我们最先想到地就是二分搜索查找,而这里从矩阵的右上角开始查找目标值就是利用了矩阵的对称性,从右上角开始搜索(matrix[0][cols - 1]),查找当前值与目标值的比较结果,决定是向左移动还是向下移动。如果当前值等于目标值,返回true。如果当前值大于目标值,向左移动(j--)。如果当前值小于目标值,向下移动(i++)。由此推出左下角来查找也是一样的。

相关推荐
Brilliantwxx6 分钟前
【C++】认识vector(概念+题目OJ)
开发语言·c++·笔记·算法
m0_6294947310 分钟前
LeetCode 热题 100-----18.矩阵置零
数据结构·leetcode·矩阵
youngerwang22 分钟前
【矩阵不是数表,而是结构的身体】
线性代数·矩阵
生成论实验室27 分钟前
《事件关系阴阳博弈动力学:识势应势之道》第十篇:识势应势——从认知到行动的完整闭环
人工智能·算法·架构·创业创新·安全架构
risc12345629 分钟前
SegmentTermsEnum#postings 和 IntersectTermsEnum#postings
算法·lucene
阿Y加油吧32 分钟前
二刷 LeetCode:两道经典贪心题复盘
算法·leetcode·职场和发展
顺顺 尼32 分钟前
程序地址空间和进程的一些操作
算法
Java成神之路-35 分钟前
【LeetCode 刷题笔记】35. 搜索插入位置 | 二分查找经典入门题
算法·leetcode
MediaTea11 小时前
AI 术语通俗词典:C4.5 算法
人工智能·算法
Navigator_Z11 小时前
LeetCode //C - 1033. Moving Stones Until Consecutive
c语言·算法·leetcode