1: //nth_element1a.cpp
3: #include <iostream>
4: #include <vector>
5: #include <algorithm>
6: using namespace std;
8: int main()
9: {
10: cout << "\nThis program illustrates the use of the STL "
11: "nth_element() algorithm (default\nversion) to partition "
12: "a vector of integers of size 12 around its 7th element. "
13: "\nThe ranges on either side of this value may or may not "
14: "be sorted, but the\nalgorithm does not guarantee this, "
15: "and you should not expect it.";
16: cout << "\nPress Enter to continue ... "; cin.ignore(80, '\n');
18: int a[] = {10, 2, 6, 11, 9, 3, 4, 12, 8, 7, 1, 5};
19: vector<int> v(a, a+12);
20: cout << "\nHere are the initial contents of the vector:\n";
21: for (vector<int>::size_type i=0; i<v.size(); i++)
22: cout << v.at(i) << " ";
23: cout << "\nPress Enter to continue ... "; cin.ignore(80, '\n');
25: cout << "\nNow we make the following call:";
26: cout << "\nnth_element(v.begin(), v.begin()+6, v.end());";
27: nth_element(v.begin(), v.begin()+6, v.end());
28: cout << "\nPress Enter to continue ... "; cin.ignore(80, '\n');
30: cout << "\nAnd here are the contents of the vector partitioned "
31: "around its 7th element:\n";
32: for (vector<int>::size_type i=0; i<v.size(); i++)
33: cout << v.at(i) << " ";
34: cout << "\nPress Enter to continue ... "; cin.ignore(80, '\n');
35: }