指定n個數(shù)字,找出其中最大的k個數(shù),這就是經(jīng)典的TopK問題
創(chuàng)新互聯(lián)公司主營巴里坤哈薩克網(wǎng)站建設(shè)的網(wǎng)絡(luò)公司,主營網(wǎng)站建設(shè)方案,app軟件開發(fā)公司,巴里坤哈薩克h5小程序制作搭建,巴里坤哈薩克網(wǎng)站營銷推廣歡迎巴里坤哈薩克等地區(qū)企業(yè)咨詢
public int[] topK(int[] array, int k) {
Arrays.sort(array);
return Arrays.copyOfRange(array, array.length - k, array.length);
}
public int[] topK(int[] array, int k) {
for(int i = 0; i < k; i++) {
for(int j = array.length - 1; j > 0; j--) {
if(array[j] > array[j - 1]) {
int tmp = array[j];
array[j] = array[j - 1];
array[j - 1] = tmp;
}
}
}
}
public Integer[] topK(int[] array, int k) {
PriorityQueue queue = new PriorityQueue<>();
for(int i = 0; i < k; i++) {
queue.add(array[i]);
}
for(int i = k; i < array.length; i++) {
if(array[i] > queue.peek()) {
queue.poll();
queue.add(array[i]);
}
}
return (Integer[])queue.toArray();
}
代碼:
public int[] topK5(int[] array, int k) {
int left = 0;
int right = array.length - 1;
//因為數(shù)組下標(biāo)是以0開始的,因此第k個的小標(biāo)為k - 1,因此傳入的為k - 1
int flag = RS(array, left, right, k - 1);
//返回值flag為第k個最大值的下標(biāo),因此需要前k個最大的值時,拷貝數(shù)組的范圍是[0, flag + 1)
return Arrays.copyOfRange(array, 0, flag + 1));
}
private int RS(int[] array, int left, int right, int k) {
if (left >= right) {
return left;
}
int index = partition(array, left, right);
int temp = index - left;
if(temp >= k) {
return RS(array, left, index - 1, k);
} else {
return RS(array, index + 1, right, k - index);
}
}
private int partition(int[] array, int left, int right) {
int tmp = array[left];
int l = left;
int r = right;
while(l < r) {
while(l < r && array[r] <= tmp) {
r--;
}
array[l] = array[r];
while(l < r && array[l] >= tmp) {
l++;
}
array[r] = array[l];
}
array[l] = tmp;
return l;
}