题目
给定一个 n x n 矩阵,其中每行和每列元素均按升序排序,找到矩阵中第k小的元素。
请注意,它是排序后的第k小元素,而不是第k个元素。
示例:
matrix = [
[ 1, 5, 9],
[10, 11, 13],
[12, 13, 15]
],
k = 8,
返回 13。
说明:
你可以假设 k 的值永远是有效的, 1 ≤ k ≤ n2 。
解题思路:
维护一个最大堆,最大堆的size始终保持k,遍历一遍这个矩阵,然后返回这个最大堆的堆顶即可得到第K小的元素。
具体代码如下:
class Solution
{
public:
int kthSmallest(vector<vector<int>>& matrix, int k)
{
int first_index = matrix.size();
int second_index = matrix[0].size();
vector<int> mylist{};
for (int i = 0; i < first_index; i++)
{
for (int j = 0; j < second_index; j++)
{
if (mylist.empty())
{
mylist.push_back(matrix[i][j]);
}
else
{
mylist.push_back(matrix[i][j]);
push_heap(mylist.begin(), mylist.end(), less<int>());
if (mylist.size() > k)
{
pop_heap(mylist.begin(), mylist.end(), less<int>());
mylist.pop_back();
}
}
}
}
return mylist[0];
}
};