最后更新于
最后更新于
给定一个 n x n 矩阵,其中每行和每列元素均按升序排序,找到矩阵中第 k 小的元素。 请注意,它是排序后的第 k 小元素,而不是第 k 个不同的元素。
示例:
提示: 你可以假设 k 的值永远是有效的,1 ≤ k ≤ n2 。
由于每一行都是排好序的数组, 可以使用归并排序的思想, 类似于链表的操作, 从每行的第一个数字开始, 结合最小堆.
首先将所有行的第一个数字入堆, 每行的第一个数字肯定是这一行最小的, 因此全局最小的一定在其中(这里一定是左上角的值为最小值)
此时堆顶的数字为最小值, 将其弹出, 然后将其所在行的下一个数字入堆, 如果这个数字已经是这一行最后一个数字了, 则无需找到新入堆数字, 堆大小-1
这样重复次, 此时堆顶的元素就是整个矩阵中第小的元素
时间复杂度为, 空间复杂度为
其实这道题是的简化版, 对于链表, 没有要求同列数字随行递增, 也没有要求每行的数字个数相同, 仍然可以使用归并排序+堆的套路解答. 但这同时也说明我们没有用到这些有用信息, 时间复杂度还有提升的空间.
二分查找的思路参考: