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# 的用户
相关推荐
x_xbx25 分钟前
LeetCode:34. 在排序数组中查找元素的第一个和最后一个位置
数据结构·算法·leetcode
weixin_5375904529 分钟前
《C程序设计语言》练习答案(练习1-13)
c语言·开发语言·c#
Ricky_Theseus34 分钟前
数据库关系代数 - 连接操作
linux·数据库·算法
绿算技术40 分钟前
宝辰股份董事长莅临绿算技术调研交流
人工智能·科技·算法
码云数智-园园1 小时前
哈希冲突的解决之道:深入理解哈希表底层原理
算法·哈希算法
a17798877121 小时前
小程序上传图像失败
小程序·c#
qq_416018721 小时前
C++中的模板方法模式
开发语言·c++·算法
天上路人1 小时前
A-59F 多功能语音处理模组在本地会议系统扩音啸叫处理中的技术应用与性能分析
人工智能·神经网络·算法·硬件架构·音视频·语音识别·实时音视频
yang_B6212 小时前
噪声处理方法
大数据·人工智能·算法
菜菜小狗的学习笔记2 小时前
剑指Offer算法题(九)搜索
数据结构·算法·深度优先