LeetCode 面试题 10.09. 排序矩阵查找

文章目录

一、题目

给定M×N矩阵,每一行、每一列都按升序排列,请编写代码找出某元素。

示例:

现有矩阵 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

给定 target = 20,返回 false

点击此处跳转题目

二、C# 题解

以右上方的元素为起点,向左下方查找,即可以看成是一个二叉查找树:

csharp 复制代码
public class Solution {
    public bool SearchMatrix(int[][] matrix, int target) {
        if (matrix.Length == 0) return false;
        int row = matrix.Length, col = matrix[0].Length, i = 0, j = col - 1;
        while (i < row && j >= 0) {
            if (target == matrix[i][j]) return true;
            if (target > matrix[i][j]) i++; // 进入右子树
            else j--;                       // 进入左子树
        }
        return false;
    }
}
  • 时间:120 ms,击败 100.00% 使用 C# 的用户
  • 内存:60.17 MB,击败 100.00% 使用 C# 的用户
相关推荐
L_Aria9 分钟前
6421. 【NOIP2019模拟11.11】匹配
c++·算法·动态规划
骇城迷影1 小时前
代码随想录:哈希表篇
算法·哈希算法·散列表
智者知已应修善业1 小时前
【PAT乙级真题解惑1012数字分类】2025-3-29
c语言·c++·经验分享·笔记·算法
每天要多喝水1 小时前
动态规划Day30:买卖股票
算法·动态规划
v_for_van1 小时前
力扣刷题记录6(无算法背景,纯C语言)
c语言·算法·leetcode
-To be number.wan2 小时前
算法学习日记 | 双指针
c++·学习·算法
样例过了就是过了2 小时前
LeetCode热题100 最大子数组和
数据结构·算法·leetcode
铸人2 小时前
再论自然数全加和 - 欧拉伽马常数
数学·算法·数论·复数
踩坑记录3 小时前
leetcode hot100 200. 岛屿数量 medium dfs
leetcode·深度优先
m0_531237173 小时前
C语言-变量,枚举常量,字符串,打印类型,转义字符
c语言·数据结构·算法