有序矩陣中第K小的元素(通俗解法)

2021-10-07 17:24:57 字數 569 閱讀 5480

給定乙個 n x n 矩陣,其中每行和每列元素均按公升序排序,找到矩陣中第 k 小的元素。

請注意,它是排序後的第 k 小元素,而不是第 k 個不同的元素。

示例:matrix = [

[ 1,  5,  9],

[10, 11, 13],

[12, 13, 15]

],k = 8,

返回 13。

//通俗解法

//先降維,二維降維一維,然後用sort進行排序,最後取第k位

public class main ,,};

system.out.println(kthsmallest(matrix, k));

} private static int kthsmallest(int matrix, int k) {

int ans = 0;

int t = 0;

int n = matrix.length;

int m = matrix[0].length;

int tmp = new int[n * m];

for (int i=0; i官方給的二分太難想了。。。

有序矩陣中第k小元素

題目 給定乙個 n x n 矩陣,其中每行和每列元素均按公升序排序,找到矩陣中第 k 小的元素。請注意,它是排序後的第 k 小元素,而不是第 k 個不同的元素。看到有序就會想到二分查詢,而本題的二分查詢十分的有趣。根據這個矩陣的定義,我們知道,最小的元素是最左上角元素,最大的元素是最左下角元素。由此...

有序矩陣中第K小的元素

給定乙個 n x n 矩陣,其中每行和每列元素均按公升序排序,找到矩陣中第k小的元素。請注意,它是排序後的第k小元素,而不是第k個元素。示例 matrix 1,5,9 10,11,13 12,13,15 k 8,返回 13。說明 你可以假設 k 的值永遠是有效的,1 k n2 分析 因為是整數,可使...

LeetCode 有序矩陣中第K小的元素

給定乙個 n x n 矩陣,其中每行和每列元素均按公升序排序,找到矩陣中第k小的元素。請注意,它是排序後的第k小元素,而不是第k個元素。示例 matrix 1,5,9 10,11,13 12,13,15 k 8,返回 13。public boolean guess int matrix,int mi...