排序矩阵中的从小到大第k个数-LintCode

在一个排序矩阵中找从小到大的第 k 个整数。
排序矩阵的定义为:每一行递增,每一列也递增。

样例:
给出 k = 4 和一个排序矩阵:

[
  [1 ,5 ,7],
  [3 ,7 ,8],
  [4 ,8 ,9],
]

返回 5。

挑战 :
使用O(k log n)的方法,n为矩阵的宽度和高度中的最大值。

思路:
与接雨水II类似,利用priority_queue构建小顶堆,在符合条件的情况下将队头元素的右边和下边入队,
将队头元素出队,进行k次。

#ifndef C401_H
#define C401_H
#include<iostream>
#include<vector>
#include<queue>
#include<functional>
using namespace std;
class Solution {
public:
    /*
    * @param matrix: a matrix of integers
    * @param k: An integer
    * @return: the kth smallest number in the matrix
    */
    int kthSmallest(vector<vector<int>> matrix, int k) {
        // write your code here
        if (matrix.empty()||k<=0)
            return 0;
        priority_queue<pair<int, int>,vector<pair<int, int>>, greater<pair<int, int>>> que;
        int row = matrix.size();
        int col = matrix[0].size();
        vector<vector<int>> visited(row, vector<int>(col, 0));
        que.push(make_pair(matrix[0][0], 0 * col + 0));
        visited[0][0] = 1;
        while (k--)
        {
            auto pairVal = que.top();
            que.pop();
            if (k == 0)
                return pairVal.first;
            int i = pairVal.second / col;
            int j = pairVal.second%col;
            if (i + 1 < row&&visited[i + 1][j] == 0)
            {
                que.push(make_pair(matrix[i + 1][j], (i + 1)*col + j));
                visited[i + 1][j] = 1;
            }
            if (j + 1 < col&&visited[i][j + 1] == 0)
            {
                que.push(make_pair(matrix[i][j + 1], i*col + (j + 1)));
                visited[i][j + 1] = 1;
            }
        }
    }
};
#endif
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值