LeetCode—有序矩阵中第k小的元素(排序+官方二分)

有序矩阵中第k小的元素(中等)

2020年7月2日

题目来源:力扣

在这里插入图片描述

力扣

  • 排序

试验的做法,二维转一维再排序,花时间费空间

class Solution {
    public int kthSmallest(int[][] matrix, int k) {
        int mlen=matrix.length;
        int[] n_matrix=new int[mlen*mlen];
        int count=0;
        for(int i=0;i<mlen;i++){
            for(int j=0;j<mlen;j++){
                n_matrix[count++]=matrix[i][j];
            }
        }
        Arrays.sort(n_matrix);
        return n_matrix[k-1];
    }
}

在这里插入图片描述

  • 二分

学习官方的二分题解,原来二分还能这么用,学到了学到了

class Solution {
    public int kthSmallest(int[][] matrix, int k) {
        //二维数组的长度,因为是n*n,所以算一个就行
        int n = matrix.length;
        //左边界
        int left = matrix[0][0];
        //右边界
        int right = matrix[n - 1][n - 1];
        //使用二分,这里的>>1就是二进制的除以2
        while (left < right) {
            int mid = left + ((right - left) >> 1);
            if (check(matrix, mid, k, n)) {
                right = mid;
            } else {
                left = mid + 1;
            }
        }
        return left;
    }
    //从左下角开始,符合小于等于mid就右移,不符合就上移,记录这一列小于mid的数量
    public boolean check(int[][] matrix, int mid, int k, int n) {
        int i = n - 1;
        int j = 0;
        int num = 0;
        while (i >= 0 && j < n) {
            if (matrix[i][j] <= mid) {
                num += i + 1;
                j++;
            } else {
                i--;
            }
        }
        return num >= k;
    }
}

在这里插入图片描述

猜你喜欢

转载自blog.csdn.net/weixin_41541562/article/details/107077999