std::ranges::nth_element
來自 cppreference.com
定義於標頭檔案 <algorithm> |
||
呼叫簽名 (Call signature) |
||
template< std::random_access_iterator I, std::sentinel_for<I> S, class Comp = ranges::less, class Proj = std::identity > |
(1) | (C++20 起) |
template< ranges::random_access_range R, class Comp = ranges::less, class Proj = std::identity > |
(2) | (C++20 起) |
重新排列 [
first,
last)
中的元素,使得
- 由 nth 指向的元素被更改為,如果
[
first,
last)
根據 comp 和 proj 排序,則該位置上出現的元素。 - 所有在此新的
nth
元素之前的元素都 _小於或等於_ 此新的 nth 元素之後的元素。也就是說,對於範圍[
first,
nth)
和[
nth,
last)
中的每個迭代器 _i_ 和 _j_,表示式 std::invoke(comp, std::invoke(proj, *j), std::invoke(proj, *i)) 評估為 false。 - 如果 nth == last,則函式無效果。
1) 元素使用給定的二元比較函式物件 comp 和投影物件 proj 進行比較。
本頁描述的類函式實體是 演算法函式物件(非正式地稱為 niebloids),即
目錄 |
[編輯] 引數
first, last | - | 定義要重新排列的元素的範圍的迭代器-哨兵對 |
r | - | 要重新排列的元素範圍 |
nth | - | 定義分割槽點的迭代器 |
comp | - | 用於比較投影元素的比較器 |
proj | - | 應用於元素的投影 |
[編輯] 返回值
1) 一個等於 last 的迭代器。
[編輯] 複雜度
平均情況下,與 ranges::distance(first, last) 呈線性關係。
[編輯] 注意
使用的演算法通常是 內省選擇(introselect),但也允許其他具有適當平均情況複雜度的 選擇演算法。
[編輯] 可能的實現
另請參閱 msvc stl、libstdc++ 和 libc++ 中的實現:(1) / (2)。
[編輯] 示例
執行此程式碼
#include <algorithm> #include <array> #include <functional> #include <iostream> #include <ranges> #include <string_view> void print(std::string_view rem, std::ranges::input_range auto const& a) { for (std::cout << rem; const auto e : a) std::cout << e << ' '; std::cout << '\n'; } int main() { std::array v{5, 6, 4, 3, 2, 6, 7, 9, 3}; print("Before nth_element: ", v); std::ranges::nth_element(v, v.begin() + v.size() / 2); print("After nth_element: ", v); std::cout << "The median is: " << v[v.size() / 2] << '\n'; std::ranges::nth_element(v, v.begin() + 1, std::greater<int>()); print("After nth_element: ", v); std::cout << "The second largest element is: " << v[1] << '\n'; std::cout << "The largest element is: " << v[0] << "\n\n"; using namespace std::literals; std::array names { "Diva"sv, "Cornelius"sv, "Munro"sv, "Rhod"sv, "Zorg"sv, "Korben"sv, "Bender"sv, "Leeloo"sv, }; print("Before nth_element: ", names); auto fifth_element{std::ranges::next(names.begin(), 4)}; std::ranges::nth_element(names, fifth_element); print("After nth_element: ", names); std::cout << "The 5th element is: " << *fifth_element << '\n'; }
輸出
Before nth_element: 5 6 4 3 2 6 7 9 3 After nth_element: 2 3 3 4 5 6 6 7 9 The median is: 5 After nth_element: 9 7 6 6 5 4 3 3 2 The second largest element is: 7 The largest element is: 9 Before nth_element: Diva Cornelius Munro Rhod Zorg Korben Bender Leeloo After nth_element: Diva Cornelius Bender Korben Leeloo Rhod Munro Zorg The 5th element is: Leeloo
[編輯] 參閱
(C++20) |
返回一個範圍中最大的元素 (演算法函式物件) |
(C++20) |
返回一個範圍中最小的元素 (演算法函式物件) |
(C++20) |
將一個範圍的元素分成兩組 (演算法函式物件) |
(C++20) |
對一個範圍的前 N 個元素進行排序 (演算法函式物件) |
部分排序給定的範圍,確保它被給定的元素劃分 (函式模板) |