File: equalrange.cc

package info (click to toggle)
c%2B%2B-annotations 13.02.02-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 13,576 kB
  • sloc: cpp: 25,297; makefile: 1,523; ansic: 165; sh: 126; perl: 90; fortran: 27
file content (54 lines) | stat: -rw-r--r-- 1,524 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
    #include <algorithm>
    #include <functional>
    #include <iterator>
    #include <iostream>
    using namespace std;

    int main()
    {
        int    range[] = {1, 3, 5, 7, 7, 9, 9, 9};
        auto past = end(range);

        pair<int *, int *>  pi;

        pi = equal_range(range, past, 6);

        cout << "Lower bound for 6: " << *pi.first << "\n"
                "Upper bound for 6: " << *pi.second << '\n';

        pi = equal_range(range, past, 7);

        cout << "Lower bound for 7: ";
        copy(pi.first, past, ostream_iterator<int>(cout, " "));
        cout << '\n';

        cout << "Upper bound for 7: ";
        copy(pi.second, past, ostream_iterator<int>(cout, " "));
        cout << '\n';

        sort(range, past, greater<int>());

        cout << "Sorted in descending order\n";

        copy(range, past, ostream_iterator<int>(cout, " "));
        cout << '\n';

        pi = equal_range(range, past, 7, greater<int>());

        cout << "Lower bound for 7: ";
        copy(pi.first, past, ostream_iterator<int>(cout, " "));
        cout << '\n';

        cout << "Upper bound for 7: ";
        copy(pi.second, past, ostream_iterator<int>(cout, " "));
        cout << '\n';
    }
    //  Displays:
    //      Lower bound for 6: 7
    //      Upper bound for 6: 7
    //      Lower bound for 7: 7 7 9 9 9
    //      Upper bound for 7: 9 9 9
    //      Sorted in descending order
    //      9 9 9 7 7 5 3 1
    //      Lower bound for 7: 7 7 5 3 1
    //      Upper bound for 7: 5 3 1