240. 搜索二维矩阵 II Python

文章目录


一、题目描述

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

提示:
m == matrix.length
n == matrix[i].length
1 <= n, m <= 300
-10^9 <= matrix[i][j] <= 10^9
每行的所有元素从左到右升序排列
每列的所有元素从上到下升序排列
-10^9 <= target <= 10^9

二、代码

代码如下:

c 复制代码
class Solution:
    def searchMatrix(self, matrix: List[List[int]], target: int) -> bool:
        r = len(matrix)
        c = len(matrix[0])
        for i in range(r):
            if matrix[i][0] == target:
                return True
            if matrix[i][0] < target:
                for j in range(c):
                    if matrix[i][j] == target:
                        return True
                    if matrix[i][j] > target:
                        break
        return False

三、解题思路

本题是对于特殊矩阵的遍历操作,由于该矩阵的每一行和每一列都满足升序,则可以先遍历行来找出目标值可能的存在的行数,然后再到行里面具体寻找每一列是否存在目标值,如果出现当前值已经比目标值大的情况,则表示后面的序列都不可能出现目标值了,直接结束当前循环;如果找到目标值,则立刻停止遍历,返回结果即可。

相关推荐
君义_noip11 小时前
CSP-S 2025 提高级 第一轮(初赛) 阅读程序(1)
算法·深度优先·信息学奥赛·初赛
脉动数据行情11 小时前
Python 实现融通金行情数据对接(实时推送 + K 线 + 产品列表)
开发语言·python
小O的算法实验室11 小时前
2026年IEEE TEVC,知识引导的竞争进化算法用于多解传感器-武器-目标分配问题,深度解析+性能实测
算法·论文复现·智能算法·智能算法改进
wltx168811 小时前
谷歌SEO如何做插床优化?
大数据·人工智能·python
khalil102011 小时前
代码随想录算法训练营Day-46 动态规划13 | 647. 回文子串、516.最长回文子序列、动态规划总结
数据结构·c++·算法·leetcode·动态规划·回文子串·回文子序列
2301_7815714211 小时前
JavaScript中Object-getOwnPropertySymbols获取方法
jvm·数据库·python
学习3人组11 小时前
柔性排产时序算法+中间过程+阶段目标 细化表格
算法·mes
he___H12 小时前
算法快与慢--哈希+双指针
算法·leetcode·哈希算法
呃呃本12 小时前
算法题(回溯)
算法
刀法如飞12 小时前
Rust数组去重的20种实现方式,AI时代用不同思路解决问题
人工智能·算法·ai编程