常用的遍历算法:
for_each();
transform(); (transform是变换的意思)
for_each(beg, end, func);
用指定函数一次对指定范围内元素进行迭代访问
该函数不能修改序列中得元素
(注意:for_each 的第三个参数, 函数对象做返回值)
#include <algorithm> #include <list> #include <iostream> using namespace std; //print为仿函数 struct print{ int count; print(){count = 0;} void operator()(int x) { cout << x << endl; ++count; } }; int main(void) { list<int> ilist; //初始化 for ( size_t i = 1; i < 10; ++i) { ilist.push_back(i); } //遍历ilist元素并打印 print p = for_each(ilist.begin(), ilist.end(), print()); //打印ilist元素个数 cout << p.count << endl; return 0; }
transform()函数
transform(inbegin1,inend1,outbegin2,op);
transform(inbegin1,inend1.inbegin2,outbegin3,op);
用指定函数依次对指定范围内元素进行迭代访问
该函数可以修改序列中的元素
将一个容器中得元素,通过op (此时op是一元函数对象),变换到另一个容器中(同一个容器中也可以)
类属行transform的作用是,将某个函数作用到某一个区间内的每一个元素上,并将该函数所返回的结构保存到另一个区间中。
将来两个容器的元素,通过op(此时的op是二元函数对象),变换到另一个容器中(同一个容器中也可以)
注意:
如果目标与源相同,tansforn() 就和 for_each()一样了;
如果想以某值替换符合规则的元素,应使用replace()的算法
/*//////////////////////////////// template < class InputIterator, class OutputIterator, class UnaryOperator > OutputIterator transform ( InputIterator first1, // 源容器的起始地址 InputIterator last1, // 源容器的终止地址 OutputIterator result, // 目标容器的起始地址 UnaryOperator op ); // 函数指针 // typedef 目标容器元素类型 (*UnaryOperator)(源容器元素类型); template < class InputIterator1, class InputIterator2, class OutputIterator, class BinaryOperator > OutputIterator transform ( InputIterator1 first1, // 源容器1的起始地址 InputIterator1 last1, // 源容器1的终止地址 InputIterator2 first2, // 源容器2的起始地址,元素个数与1相同 OutputIterator result, // 目标容器的起始地址,元素个数与1相同 BinaryOperator binary_op ); // 函数指针 // typedef 目标容器元素类型 (*BinaryOperator)(源容器1元素类型,源容器2元素类型); //*//////////////////////////////// #include <iostream> #include <algorithm> #include <vector> #include <string> using namespace std; int op_increase (int i) { return i+1; } int op_sum (int i, int j) { return i+j; } int to_upper(int c) { if (islower(c)) { return (c-32); } return c; } int to_lower(int c) { if (isupper(c)) { return c+32; } return c; } int main () { vector<int> first; vector<int> second; vector<int>::iterator it; // set some values: for (int i=1; i<6; i++) first.push_back (i*10); // first: 10 20 30 40 50 ///将first容器的元素加1赋值给second容器 second.resize(first.size()); // allocate space !!!必须预先设置一个大小与first相同 transform (first.begin(), first.end(), second.begin(), op_increase); // second: 11 21 31 41 51 cout << "second contains:"; for (it=second.begin(); it!=second.end(); ++it) { cout << " " << *it; } cout << endl; //*//////////////////////////////////////////// ///将first容器的元素与second容器的元素相加,并将得到的结果重新赋值给first transform (first.begin(), first.end(), second.begin(), first.begin(), op_sum); // first: 21 41 61 81 101 cout << "first contains:"; for (it=first.begin(); it!=first.end(); ++it) cout << " " << *it; cout << endl; //*////////////////////////////////////////////////////////////////////////// ///大小写转换///////////////////////////////////// string strsrc("Hello, World!"); string strdest; strdest.resize(strsrc.size()); // !!!必须预先设置一个大小与strsrc相同 transform(strsrc.begin(), strsrc.end(), strdest.begin(), to_upper); // 转换为大写 cout << strdest << endl; transform(strsrc.begin(), strsrc.end(), strdest.begin(), to_lower); // 转换为小写 cout << strdest << endl; //*///////////////////////////////////////// return 0; }
for_each() 和 transform() 算法比较
for_each() 速度快 不灵活
transform() 速度慢 非常灵活