1.常用算數(shù)生成算法
#include <iostream>
#include <vector>
#include <numeric>
#include <algorithm> //for_each
using namespace std;
//accumulate 累計
void test01(){
vector<int> v;
for(int i = 0;i<=100;i++){
v.push_back(i);
}
/*
template<class _InIt,
class _Ty> inline
_Ty accumulate(_InIt _First, _InIt _Last, _Ty _Val) 返回值是最終結果加上參數(shù)三譬涡!所以是用0最方便
{ // return sum of _Val and all in [_First, _Last)
return (_STD accumulate(_First, _Last, _Val, plus<>()));
}
*/
int n = accumulate(v.begin(),v.end(),0);
cout<<"n: "<<n<<endl;//5050
}
//fill algorithm 填充函數(shù)
class print{
void operatpr()(int v){
cout<<v<<" ";
}
}
void test02(){
vector<int> v;
v.resize(10);//用fill必須開空間 而reserve只是開空間 沒有初始化闪幽,所以不能再這里用
fill(v.begin(),v.end(),100);
cout<<"size:"<<v.size()<<endl;
for_each(v.begin(),v.end(),print());
cout<<endl;
}
int main(){
//test01();
test02();
return 0;
}
2.常用集合算法
iterator set_intersection(iterator beg1,iterator end1,iterator beg2,iterator end2,iterator dest);
/*
set_intersection 算法 求兩個set集合的交集
注意:兩個集合必須是有序序列
@param beg1 容器1開始迭代器
@param end1 容器1結束迭代器
@param beg2 容器2開始迭代器
@param end2 容器2結束迭代器
@param dest 目標容器開始迭代器
@return 目標容器的最后一個元素的迭代器地址
*/
iterator set_union(iterator beg1,iterator end1,iterator beg2,iterator end2,iterator dest);
/*
set_union 算法 求兩個set集合的并集
注意:兩個集合必須是有序序列
@param beg1 容器1開始迭代器
@param end1 容器1結束迭代器
@param beg2 容器2開始迭代器
@param end2 容器2結束迭代器
@param dest 目標容器開始迭代器
@return 目標容器的最后一個元素的迭代器地址
*/
iterator set_difference(iterator beg1,iterator end1,iterator beg2,iterator end2,iterator dest);
/*
set_difference 算法 求兩個set集合的差集
注意:兩個集合必須是有序序列
@param beg1 容器1開始迭代器
@param end1 容器1結束迭代器
@param beg2 容器2開始迭代器
@param end2 容器2結束迭代器
@param dest 目標容器開始迭代器
@return 目標容器的最后一個元素的迭代器地址
*/
//---------------------------------------------------------------
#include <iostream>
#include <vector>
#include <numeric>
#include <algorithm> //for_each
using namespace std;
//求兩個集合的交集
class print{
public:
void operator()(int v){
cout<<v<<" ";
}
}
void test01(){
vector<int> v1,v2,v3;
for (int i = 0; i < 10; ++i)
{
v1.push_back(i);
}
for (int i = 5; i < 15; ++i)
{
v2.push_back(i);
}
/*
template<class _InIt1,
class _InIt2,
class _OutIt> inline
_OutIt set_intersection(_InIt1 _First1, _InIt1 _Last1,
_InIt2 _First2, _InIt2 _Last2, _OutIt _Dest)
{ // AND sets [_First1, _Last1) and [_First2, _Last2), using operator<
return (_STD set_intersection(_First1, _Last1, _First2, _Last2, _Dest,
less<>()));
}
*/
v3.resize(min(v1.size(),v2.size()));
vector<int>::iterator myEnd = set_intersection(v1.begin(),v1.end(),v2.begin(),v2.end(),v3.begin());
//for_each(v3.begin(),v3.end(),print());
//多余的位置會顯示0,怎么解決涡匀?
//set_intersection的返回值,是一個迭代器溉知!一個知道尾部的迭代器陨瘩!
for_each(v3.begin(),myEnd,print());
}
//求兩個容器的并集
void test02(){
vector<int> v1,v2,v3;
for (int i = 0; i < 10; ++i)
{
v1.push_back(i);
}
for (int i = 5; i < 15; ++i)
{
v2.push_back(i);
}
/*
template<class _InIt1,
class _InIt2,
class _OutIt> inline
_OutIt set_union(_InIt1 _First1, _InIt1 _Last1,
_InIt2 _First2, _InIt2 _Last2, _OutIt _Dest)
{ // OR sets [_First1, _Last1) and [_First2, _Last2), using operator<
return (_STD set_union(_First1, _Last1, _First2, _Last2, _Dest,
less<>()));
}
*/
v3.resize(v1.size()+v2.size());
vector<int>::iterator myEnd = set_union(v1.begin(),v1.end(),v2.begin(),v2.end(),v3.begin());
for_each(v3.begin,myEnd,print());
}
//求差集
void test03(){
vector<int> v1,v2,v3;
for (int i = 0; i < 10; ++i)
{
v1.push_back(i);
}
for (int i = 5; i < 15; ++i)
{
v2.push_back(i);
}
v3.resize(max(v1.size(),v2.size()));
vector<int>::iterator myEnd = set_difference(v1.begin(),v1.end(),v2.begin(),v2.end(),v3.begin());
for_each(v3.begin,myEnd,print());
}
int main(){
//test01();
//test02();
test03();
return 0;
}
3.distance和for_each反向
#include <iostream>
#include <vector>
#include <algorithm>
using namespace std;
//distance 用法
void test01(){
vector<int> v;
for(int i = 10; i < 20 ; i++){
v.push_back(i);
}
for(vector<int>::iterator it = v.begin();it != v.end();it++)
{
// cout<<distance(v.begin(),it)<<endl;//0 1 2 3 4 5 6 ...就是參數(shù)二和參數(shù)一的距離
int index = distance(v.begin(),it);
cout<<v[index]<<" ";//10 11 ......
}
cout<<endl;
}
//for_each修改容器元素的值
void print(int &v){
v = v + 100;//因為要深度修改 所以是引用
}
void print2(const int &v){
cout<<v<<" ";
}
void test02(){
vector<int> v;
for(int i = 10; i < 20 ; i++){
v.push_back(i);
}
for_each(v.begin(),v.end(),print2);//打印 不修改
cout<<endl;
for_each(v.begin(),v.end(),print);//只修改 不打印
for_each(v.begin(),v.end(),print2);//打印 不修改
cout<<endl;
}
//for_each逆向遍歷
void test03(){
vector<int> v;
for(int i = 10; i < 20 ; i++){
v.push_back(i);
}
for_each(v.begin(),v.end(),print2);
cout<<endl;
for_each(v.rbegin(),v.rend(),print2);
cout<<endl;
}
int main(){
//test01();
//test02();
test03();
return 0;
}