劍指offer 最小的K個數

2021-07-05 14:06:34 字數 464 閱讀 6473

華電北風吹

天津大學認知計算與應用重點實驗室

日期:2015/10/4

題目描述

輸入n個整數,找出其中最小的k個數。例如輸入4,5,1,6,2,7,3,8這8個數字,則最小的4個數字是1,2,3,4,。

解析:基於插入排序的思想可以想到使用乙個長度為k的排序陣列儲存最小的k個元素,複雜度o(nk)。基於堆排序的思想可以想到對構建好的小根堆,進行k次取堆頂元素也可以達到目標,複雜度o(n+klog(n))。

class solution 

for (int i = 0; i0, n - i - 1);

}return v;

}void heapadjust(vector

&input, int k, int length)}}

void swap(int &a, int &b)

};

劍指offer 最小k個數

1.題目 輸入n個整數,找出其中最小的k個數。例如輸入4,5,1,6,2,7,3,8這8個數字,則最小的4個數字是1,2,3,4,2.方法 1 基於堆排序演算法,構建最大堆。時間複雜度為o nlogk 2 如果用快速排序,時間複雜度為o nlogn 3 如果用插入排序,時間複雜度為o n 2 3.演...

《劍指offer》最小的K個數

輸入n個整數,找出其中最小的k個數。例如輸入4,5,1,6,2,7,3,8這8個數字,則最小的4個數字是1,2,3,4,輸入給整數陣列,和k 找出其中最小的k個數 class solution 1 先用插入排序對陣列中數進行排序。2 取出有序陣列中最小的kge。附 這只是乙個比較簡單的方法。如果考慮...

劍指offer 最小的K個數

輸入乙個字串,按字典序列印出該字串中字元的所有排列。例如輸入字串abc,則列印出由字元a,b,c所能排列出來的所有字串abc,acb,bac,bca,cab和cba。結果請按字母順序輸出。這道題目我是參考乙個部落格的,具體位址找不到了,這裡我就說說現在我對這道題目的理解吧,這道題目核心就是遞迴,可能...