指定n個數字,找出其中最大的k個數,這就是經典的TopK問題
創新互聯公司主營巴里坤哈薩克網站建設的網絡公司,主營網站建設方案,app軟件開發公司,巴里坤哈薩克h5小程序制作搭建,巴里坤哈薩克網站營銷推廣歡迎巴里坤哈薩克等地區企業咨詢
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<Integer> 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;
//因為數組下標是以0開始的,因此第k個的小標為k - 1,因此傳入的為k - 1
int flag = RS(array, left, right, k - 1);
//返回值flag為第k個最大值的下標,因此需要前k個最大的值時,拷貝數組的范圍是[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;
}
分享文章:TopK問題有幾種解決辦法?
鏈接URL:http://vcdvsql.cn/article40/iipdeo.html
成都網站建設公司_創新互聯,為您提供定制開發、搜索引擎優化、企業網站制作、網站排名、ChatGPT、做網站
聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯