378. 有序矩阵中第K小的元素(排序或者二分)
2021-05-03 22:30
标签:排序 load 图片 -- 二维 href 二维矩阵 kth cto 378. 有序矩阵中第K小的元素 378. 有序矩阵中第K小的元素(排序或者二分) 标签:排序 load 图片 -- 二维 href 二维矩阵 kth cto 原文地址:https://www.cnblogs.com/Vampire6/p/13196377.html
第一种方法:将二维矩阵中的数存起来,然后排序输出第k个,耗时较多
class Solution {
public:
int kthSmallest(vector
第二种方法:利用二分,左上角的数最小,右下角的数最大,取个mid,然后在矩阵中找出小于等于mid的数cnt
如果cnt
当cnt>=k的时候,说明小于等于mid的数已经超过k了,mid比我们要求的数肯定大,那么将右端点为mid即可,在左边查找。
至于怎么找矩阵中小于等于mid的个数,我们可以从矩阵左下角开始找,当该位置的数
就是该列第i行的上面的所有的元素都小于等于mid,累加即可,同时列指针j++;
如果该位置的数大于了mid,那么只要将行指针向上i--即可。复杂度比第一种方法小得多,耗时短。
class Solution {
public:
bool check(vector