news 2026/4/3 6:25:20

LeetCode 378 有序矩阵中第 K 小的元素

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
LeetCode 378 有序矩阵中第 K 小的元素


文章目录

    • 摘要
    • 描述
    • 题解答案
    • 题解代码分析
      • 为什么这是“二分答案”的题
      • 统计 ≤ mid 的元素个数
      • Swift 可运行 Demo 代码
      • 代码拆解说明
        • 1. 为什么 `left` 和 `right` 这样初始化
        • 2. `count < k` 为什么要 `left = mid + 1`
        • 3. 为什么最后直接返回 `left`
    • 示例测试及结果
    • 时间复杂度
    • 空间复杂度
    • 总结

摘要

LeetCode 378「有序矩阵中第 K 小的元素」是一道非常容易被写“重”的题

很多人第一反应是:

既然矩阵是有序的,那我全部摊平成数组,再排序不就好了?

没错,能过,但空间复杂度直接炸到 O(n²),而题目明确告诉你:

你必须用更省内存的方式。

这道题真正考的不是排序,而是你有没有意识到:
“答案本身也是有序的,可以用二分去猜。”

这篇文章会重点讲清楚:

  • 为什么这是一个“对值域做二分”的问题
  • 为什么不需要真的把第 k 个元素找出来
  • Swift 下如何写出一个稳定、易读的实现

描述

题目给你一个n x n的矩阵matrix,并保证:

  • 每一行是升序
  • 每一列也是升序

注意这里有一个很重要的点:

它不是整体排序后的第 k 个“不同元素”,
而是排序后的位置第 k 个元素

比如:

[1,5,9, 10,11,13, 12,13,15]

展开后是:

[1,5,9,10,11,12,13,13,15]

第 8 个元素是13,而不是跳过重复。

题解答案

这道题最主流、也最稳妥的解法是:

对值域做二分查找 + 利用矩阵有序性统计 ≤ mid 的元素个数

核心思路一句话总结:

  • 矩阵是有序的
  • 第 k 小的值,一定在[最小值, 最大值]这个区间里
  • 我们不关心它在哪,只关心“小于等于某个值的数有多少个”

题解代码分析

为什么这是“二分答案”的题

很多人卡在一个误区里:

二分不是只能用在数组索引上吗?

其实不是。
只要答案满足单调性,就能二分。

在这道题中:

  • 值越小

    • ≤ 这个值的元素数量越少
  • 值越大

    • ≤ 这个值的元素数量越多

这是一个天然的单调关系。

统计 ≤ mid 的元素个数

这是整道题最关键的地方。

因为矩阵行列都有序,我们可以这样做:

  • 左下角开始

  • 如果当前值 ≤ mid

    • 说明这一列上面的都 ≤ mid
    • 一次性加一整列
  • 如果当前值 > mid

    • 往上移动

这个过程是O(n)的。

Swift 可运行 Demo 代码

classSolution{funckthSmallest(_matrix:[[Int]],_k:Int)->Int{letn=matrix.countvarleft=matrix[0][0]varright=matrix[n-1][n-1]whileleft<right{letmid=left+(right-left)/2letcount=countLessOrEqual(matrix,mid)ifcount<k{left=mid+1}else{right=mid}}returnleft}privatefunccountLessOrEqual(_matrix:[[Int]],_target:Int)->Int{letn=matrix.countvarrow=n-1varcol=0varcount=0whilerow>=0&&col<n{ifmatrix[row][col]<=target{count+=row+1col+=1}else{row-=1}}returncount}}

代码拆解说明

1. 为什么leftright这样初始化
varleft=matrix[0][0]varright=matrix[n-1][n-1]

因为:

  • 矩阵整体是有序的
  • 左上角是最小值
  • 右下角是最大值

这是值域的天然边界

2.count < k为什么要left = mid + 1

这一步非常关键。

含义是:

  • 当前mid太小
  • 小于等于mid的元素还不够k
  • 第 k 小的数一定在右边
3. 为什么最后直接返回left

因为循环结束条件是:

left==right

而这个值,刚好是:

第一个满足“≤ 它的元素个数 ≥ k”的数

也就是第 k 小的元素。

示例测试及结果

letsolution=Solution()print(solution.kthSmallest([[1,5,9],[10,11,13],[12,13,15]],8))// 13print(solution.kthSmallest([[-5]],1))// -5

输出结果:

13 -5

时间复杂度

  • 二分次数:log(maxValue - minValue)
  • 每次统计:O(n)

整体复杂度:

O(n * log(range))

n <= 300的限制下,非常安全。

空间复杂度

除了几个变量,没有额外数据结构:

O(1)

完全满足题目的进阶要求。

总结

LeetCode 378 是一道非常适合用来训练“二分答案思维”的题

  • 不在数组上二分
  • 而是在“可能的结果范围”上二分

这种思路在实际开发中也很常见,比如:

  • 资源分配的最小可行值
  • 系统阈值调优
  • 延迟、吞吐量的临界点搜索

如果你能把这道题讲清楚,
那你对“二分”的理解,已经明显高于只会套模板的人了。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/3/27 2:51:29

救命神器10个AI论文工具,MBA毕业论文轻松搞定!

救命神器10个AI论文工具&#xff0c;MBA毕业论文轻松搞定&#xff01; AI 工具&#xff0c;让论文写作不再“难” 在当前的学术环境中&#xff0c;MBA 学生面临着越来越高的论文写作要求。无论是选题、大纲搭建&#xff0c;还是内容撰写与降重&#xff0c;每一个环节都可能成为…

作者头像 李华
网站建设 2026/3/30 22:59:42

2026校招薪资报告:AI/大模型岗位领跑,附完整学习路径与资料包

2026届校招分析显示&#xff1a;AI/大模型岗位薪资最高(60w-90w)&#xff0c;需求激增需掌握Transformer、RAG等技术。测试开发和客户端是性价比之选。学历显著影响薪资起点(双非本科6k至985硕30k)。文章提供大模型学习四阶段路径&#xff0c;从初阶应用到商业闭环&#xff0c;…

作者头像 李华
网站建设 2026/3/24 18:21:12

c+++核心介绍

C 核心介绍C 是由 Bjarne Stroustrup 在 1980 年代基于 C 语言扩展而来的编程语言&#xff0c;核心特点是兼容 C 语言且新增了面向对象编程&#xff08;OOP&#xff09;特性&#xff0c;同时保留了对底层硬件的直接操控能力&#xff0c;因此被称为 “混合范式语言”—— 既支持…

作者头像 李华
网站建设 2026/4/2 2:06:59

IT资产组合管理:优化IT资产实现业务价值最大化

在金融领域&#xff0c;投资组合管理涉及战略性选择符合投资者财务目标和风险承受能力的投资组合。这种方法同样适用于IT系统组合&#xff0c;但需要增加一个维度&#xff1a;IT部门还必须评估组合中每项资产的运营绩效。当今的IT环境由传统系统、云端系统以及人工智能等新兴前…

作者头像 李华