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# 的用户
相关推荐
清风拂山岗 明月照大江2 分钟前
简单文件 IO 示例:使用系统调用读写文件
开发语言·c++·算法
Hcoco_me10 分钟前
大模型面试题15:DBSCAN聚类算法:步骤、缺陷及改进方向
算法·数据挖掘·聚类
AI绘画哇哒哒14 分钟前
AI 智能体长期记忆系统架构设计与落地实践
人工智能·学习·算法·ai·程序员·产品经理·转行
武藤一雄17 分钟前
C#:Linq大赏
windows·后端·microsoft·c#·.net·.netcore·linq
加藤不太惠23 分钟前
【无标题】
java·数据结构·算法
金色旭光26 分钟前
目标追踪算法+卡尔曼滤波原理+ByteTrack使用
算法
@年年42 分钟前
C#十字线小工具
c#
学学学无无止境1 小时前
力扣-从中序与后序遍历序列构造二叉树
leetcode
夏乌_Wx1 小时前
练题100天——DAY22:数字拼接+只出现一次的数字
java·数据结构·算法
listhi5201 小时前
MOEAD算法实现详解(基于Python与MATLAB)
python·算法·matlab