在c++的stl库中,提供了nth_element这样一个函数
它的用法是nth_element(a+l,a+k,a+r)
这样它会使a这个数组中区间[l,r)[l,r)内的第kk小的元素处在第kk个位置上(相对位置)
但是它并不保证其他元素有序!
#include<iostream>
#include<algorithm>
using namespace std;
int main() {
static int a[15] = {0, 1, 2, 5, 7, 3, 4, 1};
nth_element(a + 1, a + 4, a + 8);
for (int i = 1; i <= 8; i++) printf("%d ", a[i]); printf("\n");
return 0;
}
2187

被折叠的 条评论
为什么被折叠?



