蓝桥与力扣刷题(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++)。由此推出左下角来查找也是一样的。

相关推荐
2zcode2 分钟前
项目文档:基于MATLAB语音信号变声算法设计与实现
算法·matlab·语音识别
指令集梦境8 分钟前
图解:单调栈算法模板(Java语言)
java·开发语言·算法
生成论实验室30 分钟前
自动驾驶:一个自主运动的系统
人工智能·算法·机器学习·语言模型·机器人·自动驾驶·安全架构
sheeta199832 分钟前
LeetCode 每日一题笔记 日期:2026.06.16 题目:3612. 字符串特殊符号处理
笔记·算法·leetcode
CoderYanger35 分钟前
A.每日一题:2095. 删除链表的中间节点
java·数据结构·程序人生·leetcode·链表·面试·职场和发展
青山木39 分钟前
Hot 100 --- 矩阵置零
线性代数·算法·leetcode·矩阵·哈希算法
Jasmine_llq40 分钟前
《B4264 [GESP202503 四级] 二阶矩阵》
线性代数·算法·矩阵·二维矩阵遍历枚举所有2×2矩阵·交叉乘积等式条件判断·输入输出快读加速·长整型防溢出计数统计
不知名的老吴1 小时前
面经经验分享|算法和数据结构考察
数据结构·经验分享·算法
叫我:松哥1 小时前
基于Python flask的中学可控智能命题系统设计与实现,整合遗传算法、DeepSeek 大模型及数据库技术构建一体化应用
数据库·人工智能·python·算法·机器学习·flask·遗传算法
CoderYanger1 小时前
A.每日一题:3612. 用特殊操作处理字符串 I
java·程序人生·leetcode·面试·职场和发展·学习方法·改行学it