C++中std::partial_sort的使用小結(jié)
std::partial_sort
是 C++ 標(biāo)準(zhǔn)庫中的一個(gè)算法,它可以對(duì)容器中的一部分元素進(jìn)行排序,使得前 N
個(gè)元素按順序排列,而不保證剩余部分有序。它的時(shí)間復(fù)雜度為 O(N log N + (M-N)),其中 M 是整個(gè)范圍的大小,N 是要排序的元素?cái)?shù)量。
1. 語法
#include <algorithm> template< class RandomIt > void partial_sort( RandomIt first, RandomIt middle, RandomIt last ); template< class RandomIt, class Compare > void partial_sort( RandomIt first, RandomIt middle, RandomIt last, Compare comp );
first
:要排序的范圍的起始迭代器。middle
:指定排序后的前N
個(gè)元素的終點(diǎn),即first + N
。last
:排序范圍的結(jié)束迭代器。comp
(可選):自定義比較函數(shù)。
2. 基本用法
#include <iostream> #include <vector> #include <algorithm> int main() { std::vector<int> vec = {7, 3, 9, 1, 6, 2, 8, 5, 4}; // 僅對(duì)前 5 個(gè)元素排序 std::partial_sort(vec.begin(), vec.begin() + 5, vec.end()); // 輸出前 5 個(gè)排序后的元素 std::cout << "前 5 個(gè)最小的元素: "; for (int i = 0; i < 5; ++i) { std::cout << vec[i] << " "; } std::cout << "\n"; // 輸出整個(gè)數(shù)組 std::cout << "整個(gè)數(shù)組: "; for (int num : vec) { std::cout << num << " "; } std::cout << "\n"; return 0; }
輸出
前 5 個(gè)最小的元素: 1 2 3 4 5
整個(gè)數(shù)組: 1 2 3 4 5 9 8 7 6
注意:前 5 個(gè)元素是有序的,但整個(gè)數(shù)組仍然是部分無序的。
3. 使用自定義比較函數(shù)
可以使用 std::greater<int>()
進(jìn)行降序排序:
#include <iostream> #include <vector> #include <algorithm> int main() { std::vector<int> vec = {7, 3, 9, 1, 6, 2, 8, 5, 4}; // 獲取前 5 個(gè)最大的元素(降序) std::partial_sort(vec.begin(), vec.begin() + 5, vec.end(), std::greater<int>()); // 輸出前 5 個(gè)排序后的元素 std::cout << "前 5 個(gè)最大的元素: "; for (int i = 0; i < 5; ++i) { std::cout << vec[i] << " "; } std::cout << "\n"; return 0; }
輸出
前 5 個(gè)最大的元素: 9 8 7 6 5
4. 與 std::sort 和 std::nth_element 的比較
算法 | 作用 | 復(fù)雜度 | 適用場景 |
---|---|---|---|
std::sort | 全部排序 | O(N log N) | 需要排序整個(gè)序列 |
std::partial_sort | 僅保證前 N 個(gè)元素有序 | O(N log N + (M-N)) | 只需要最小/最大 N 個(gè)有序元素 |
std::nth_element | 只保證 N 處的元素正確,左側(cè)比它小,右側(cè)比它大 | O(M) | 只需要找到第 N 小的元素,且不關(guān)心其他元素順序 |
5. 適用場景
- 求前 K 個(gè)最小/最大值
- 數(shù)據(jù)流處理(流式計(jì)算)
- Top-K 查詢
- 快速獲取排名前 N 的元素
到此這篇關(guān)于C++中std::partial_sort的使用小結(jié)的文章就介紹到這了,更多相關(guān)C++ std::partial_sort內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
C語言合并兩個(gè)帶頭節(jié)點(diǎn)升序排列鏈表
這篇文章主要為大家詳細(xì)介紹了C語言合并兩個(gè)帶頭節(jié)點(diǎn)升序排列鏈表的方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-03-03C++?AVL樹的兩單旋和兩雙旋的項(xiàng)目實(shí)踐
本文主要介紹了C++?AVL樹的兩單旋和兩雙旋的項(xiàng)目實(shí)踐,根據(jù)節(jié)點(diǎn)插入位置的不同,AVL樹的旋轉(zhuǎn)分為四種,下面就來介紹一下,感興趣的可以了解一下2024-03-03C語言實(shí)現(xiàn)查詢自動(dòng)售貨機(jī)中的商品價(jià)格【實(shí)例分享】
本文主要介紹了C語言實(shí)現(xiàn)查詢自動(dòng)售貨機(jī)中的商品價(jià)格的相關(guān)資料。具有很好的參考價(jià)值。下面跟著小編一起來看下吧2017-04-04C語言實(shí)現(xiàn)學(xué)生成績管理系統(tǒng)課程設(shè)計(jì)
這篇文章主要為大家詳細(xì)介紹了C語言實(shí)現(xiàn)學(xué)生成績管理系統(tǒng)課程設(shè)計(jì),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-07-07C++?OpenCV裁剪圖片時(shí)發(fā)生報(bào)錯(cuò)的解決方式
在圖像處理中,我們經(jīng)常根據(jù)需要截取圖像中某一區(qū)域做處理,下面這篇文章主要給大家介紹了關(guān)于C++?OpenCV裁剪圖片時(shí)發(fā)生報(bào)錯(cuò)的解決方式,文中通過圖文介紹的非常詳細(xì),需要的朋友可以參考下2022-07-07C++利用stringstream進(jìn)行數(shù)據(jù)類型轉(zhuǎn)換實(shí)例
這篇文章主要介紹了C++利用stringstream進(jìn)行數(shù)據(jù)類型轉(zhuǎn)換的方法,實(shí)例分析了使用stringstream進(jìn)行string轉(zhuǎn)int的操作技巧,需要的朋友可以參考下2015-01-01