1: //find_end1a.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 find_end() "
11: "algorithm (default\nversion) to find the last occurrence of "
12: "one range of integer values in a\nvector within another range "
13: "of integer values, also in a vector.";
14: cout << "\nPress Enter to continue ... "; cin.ignore(80, '\n');
16: int a1[] = {1, 2, 3, 4, 5, 6, 7, 8, 3, 4, 5, 9, 10, 11};
17: vector<int> v1(a1, a1+14);
18: cout << "\nHere are the contents of v1:\n";
19: for (vector<int>::size_type i=0; i<v1.size(); i++)
20: cout << v1.at(i) << " ";
21: cout << "\nPress Enter to continue ... "; cin.ignore(80, '\n');
23: int a2[] = {3, 4, 5};
24: vector<int> v2(a2, a2+3);
25: cout << "\nHere are the contents of v2:\n";
26: for (vector<int>::size_type i=0; i<v2.size(); i++)
27: cout << v2.at(i) << " ";
28: cout << "\nPress Enter to continue ... "; cin.ignore(80, '\n');
30: vector<int>::iterator p;
32: p = find_end(v1.begin(), v1.end(), v2.begin(), v2.end());
33: if (p != v1.end())
34: cout << "\nThe last instance of v2 in v1 begins at location "
35: << (int)(p-v1.begin()+1) << ".";
36: else
37: cout << "\nNo instance of v2 was found in v1.";
38: cout << "\nPress Enter to continue ... "; cin.ignore(80, '\n');
39: }