算法名稱 |
generate |
參數 |
容器遍歷起始位置,容器遍歷最後一個位置,特定的動作(函數) |
返回值 |
void |
作用 |
以指定動作運算結果填充特定範圍內的元素內容 |
算法名稱 |
generate_n |
參數 |
容器遍歷起始位置,容器遍歷的個數,特定的動作(函數) |
返回值 |
返回一個迭代器 |
作用 |
以指定動作的運算結果填充n個元素內容 |
#include <iostream>
#include <vector>
#include <deque>
#include <algorithm>
#include <numeric>
#include <time.h>
using namespace std;
void showArr(vector<int> Arr)
{
vector<int>::iterator iteArr = Arr.begin();
for (iteArr ; iteArr != Arr.end(); iteArr++)
{
cout << *iteArr << "\t";
}
cout << endl;
}
vector<int> createStaticArr()
{
vector<int> vectorInt;
vectorInt.push_back(1);
vectorInt.push_back(2);
vectorInt.push_back(3);
vectorInt.push_back(4);
vectorInt.push_back(5);
vectorInt.push_back(6);
vectorInt.push_back(7);
vectorInt.push_back(8);
showArr(vectorInt);
return vectorInt;
}
void main()
{
vector<int> arr1 = createStaticArr();
cout << endl;
generate(arr1.begin(), arr1.begin() + 5, []() {return 5; });
showArr(arr1);
cout << endl;
generate_n(arr1.begin(), 2, []() {return 2; });
showArr(arr1);
cout << endl;
}
結果: