面試題30、輸入n個(gè)整數(shù),找出其中最小的k個(gè)數(shù),例如輸入4,5,1,6,2,7,3,8這個(gè)8個(gè)數(shù)字,則最小的4個(gè)數(shù)字是1,2,3,4
import java.util.ArrayList;
import java.util.Comparator;
import java.util.PriorityQueue;
public class Solution {
public ArrayList<Integer> GetLeastNumbers_Solution(int [] input, int k) {
ArrayList<Integer> result = new ArrayList<Integer>();
if(k > input.length || k<=0){
return result;
}
//定義排列的順序
Comparator<Integer> cmp;
cmp = new Comparator<Integer>(){
public int compare(Integer o1, Integer o2){
return o2-o1;
}
};
//java中的最大堆結(jié)構(gòu)
PriorityQueue<Integer> qi = new PriorityQueue<Integer>(k,cmp);
//添加k個(gè)元素,按照從小到大的順序進(jìn)行排列,能夠逆序
int i = 0;
for(;i<k;i++){
qi.add(input[i]);
}
// System.out.println("queue輸出"+qi.size());
// while(!qi.isEmpty()){
// System.out.print(qi.poll()+" ");
// }
for(;i<input.length ;i++){
if(input[i] < qi.peek()){
qi.poll();
qi.add(input[i]);
}
}
while(!qi.isEmpty()){
result.add(qi.poll());
}
return result;
}
}
《劍指offer》中和大數(shù)據(jù)相關(guān)的題目
最后編輯于 :
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。
相關(guān)閱讀更多精彩內(nèi)容
- 背景 一年多以前我在知乎上答了有關(guān)LeetCode的問題, 分享了一些自己做題目的經(jīng)驗(yàn)。 張土汪:刷leetcod...
- 1. Java基礎(chǔ)部分 基礎(chǔ)部分的順序:基本語法,類相關(guān)的語法,內(nèi)部類的語法,繼承相關(guān)的語法,異常的語法,線程的語...
- Java經(jīng)典問題算法大全 /*【程序1】 題目:古典問題:有一對兔子,從出生后第3個(gè)月起每個(gè)月都生一對兔子,小兔子...