更新 5. 有序矩阵的 Kth Element 二分查找法实现
原本实现,在计算 matrix[i][j] <= mid 的 count 时,耗时较高
This commit is contained in:
parent
5f005e2263
commit
205a1532da
@ -146,20 +146,26 @@ return 13.
|
|||||||
|
|
||||||
```java
|
```java
|
||||||
public int kthSmallest(int[][] matrix, int k) {
|
public int kthSmallest(int[][] matrix, int k) {
|
||||||
int m = matrix.length, n = matrix[0].length;
|
int n = matrix.length;
|
||||||
int lo = matrix[0][0], hi = matrix[m - 1][n - 1];
|
int low = matrix[0][0], high = matrix[n-1][n-1];
|
||||||
while (lo <= hi) {
|
while (low < high) {
|
||||||
int mid = lo + (hi - lo) / 2;
|
int mid = (low + high) >> 1;
|
||||||
int cnt = 0;
|
int count = 0;
|
||||||
for (int i = 0; i < m; i++) {
|
for (int i = 0, j = n - 1; i < n && j >= 0;) {
|
||||||
for (int j = 0; j < n && matrix[i][j] <= mid; j++) {
|
if (matrix[i][j] <= mid) {
|
||||||
cnt++;
|
count += j + 1;
|
||||||
|
i++;
|
||||||
|
} else {
|
||||||
|
j--;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (cnt < k) lo = mid + 1;
|
if (count < k) {
|
||||||
else hi = mid - 1;
|
low = mid + 1;
|
||||||
|
} else {
|
||||||
|
high = mid;
|
||||||
}
|
}
|
||||||
return lo;
|
}
|
||||||
|
return high;
|
||||||
}
|
}
|
||||||
```
|
```
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user