C++泛型编程总结(二)
来源:互联网 发布:linux搭建hadoop 编辑:程序博客网 时间:2024/06/08 14:38
目录:
7.插入insert()的变形
8.Function Object
9.设计泛型算法Function Object Adapter与Insertion adapter
10.关联容器map和set
11.iostream Iterator
7.插入insert()的变形
- iterator insert(iterator position,elemType value),插入到position之前,并返回插入元素的iterator,可用于将ival插入ilist并维持其递增次序
for( list<int>::iterator it=ilist.begin();it != ilist.end();++it){ if(*it>value) ilist.insert(it,value); break; } if(it==ilist.end()) ilist.push_back(value);
- void insert(iterator position,int count,elemType value)可在position之前插入count个值为value的元素
- void insert(iterator1 position,iterator2 first,iterator2 last)可在position之前插入[first,last)所标示的各个元素
- void insert(iterator position)可在position之前插入元素,初值为其所属类型的默认值
- iterator erase(iterator posit)可删除posit所指的元素,返回被删除元素的下一个iterator
list<string>::iterator it =find(slist.begin(),slist.end(),str);slist.erase(it); //删除值为str的元素
iterator erase(iterator first,iterator last)删除[first,last)范围内的元素,返回被删除的最后一个元素的下一个iterator
8.Function Object
- 实现了原本可能以独立函数定义的实物 #include<functional>
- 目的是提高效率,令call运算符成为inline,消除“通过函数指针来调用函数”时需要付出的额外代价。
- 分为三类
- 算术arithmetic:plus<type>,minus<type>,negate<type>,multiplies<type>,divides<type>,modules<type>
- 关系relational:less<type>,less_equal<type>,greater<type>,greater_equal<type>,equal_to<type>,not_equal_to<type>
- 逻辑logical:logical_and<type>,logical_or<type>,logical_not<type>
例子:sort(vec.begin(),vec.end(),greater<int>());
9.设计泛型算法Function Object Adapter与Insertion adapter
- bind1st:将指定值绑定至第一操作数
- bind2nd:将指定值绑定至第二操作数
以下例子不仅展示bind2nd,也展示Filter()
消除:1.容器类型,2.元素类型,3.“比较操作”参数化,使得同时支持函数指针和fun object,4.可自定义比较操作
template<typename InputIterator,typename OutputIterator, typename ElemType,typename Comp>OutputIterator Filter(InputIterator first,InputIterator last, OutputIterator OutStorage,const ElemType& value,Comp pFunction){ while( (first = find_if(first,last,bind2nd(pFunction,value)) )!= last ){ cout<<"Found Value:"<<*first<<endl; *OutStorage++ = *first++;} return OutStorage;}int main(){ int ia[8] = {12,8,43,0,6,21,3,7}; vector<int> vec(ia,ia+8); //下面这个容器用来储存过滤结果 int ia2[8]; vector<int> ivec2(8); cout<<"array values less than 8\n"; Filter(ia,ia+8,ia2,8,less<int>()); cout<<"vector values greater than 8\n"; Filter(vec.begin(),vec.end(),ivec2.begin(),8,greater<int>());}
- back_inserter(ivec2):以push_back()的方式插入代替assignment
- front_inserter(ivec2):以push_front()的方式插入代替assignment,只适用于list和deque
- inserter(ivec2,ivec.end):以容器的insert()的方式插入代替assignment,第一个参数是容器,第二个是迭代器,指向容器内插入操作的起点
//filter的写法不变#include<iterator>vector<int> ivec2; Filter(vec.begin(),vec.end(),back.begin(),back_inserter(ivec2),8,greater<int>());
10.关联容器map和set
注意这两个容器都是基于红黑树的,要实现时间复杂度为log(k)的插入删除操作,可以利用这两个容器
(1)map
- map<string,int> mword[word]++,存在key值word就会给value值+1,不存在就会创建key值word,value为默认值0,然后+1
- 一个key只有一份
- it.first(),it.second(),要遍历可以用iterator不断自增,知道it == mword.end()
- mword.find("vermmer"),找到就返回迭代器指向pair类型,否则返回end();
- mword.count(word),返回word出现的次数
(2)set
- 只存储key值,并按照默认less-than排列,遍历可用iterator
- 可用来存储map中想要的or不想要的key
- 一个key只有一份
ia[10]={1,3,5,8,5,3,1,5,8,1};vector<int> vec(ia,ia+10)set<int> iset<vec.begin(),vec.end()>//{1,3,5,8}iset.insert(ival) //插入一个iset.insert(vec.begin(),vec.end()) //插入
11.iostream Iterator
认识就好了,这种输入还好,输出有些局限
#include<iostream>#include<vector>#include<string>#include<iterator>#include<algorithm>using namespace std;int main(){ istream_iterator<string> is(cin); istream_iterator<string> eof; //不指定就是end-of-file vector<string> text; copy(is,eof,back_inserter(text)); //text没有设置大小,需指定插入方式 sort(text.begin(),text.end()); //排序 ostream_iterator<string> os(cout," "); //输出间隔为空格 copy(text.begin(),text.end(),os);}从文件中读写#include<fstream>ifstream infile("input_file.txt");ofstream outfile("output_file.txt");if(!infile || !outfile){……}istream_iterator<string> is(infile);
0 0
- 读《C专家编程》总结(二)
- linux c 编程模板总结(二)
- C++泛型编程总结(二)
- 【c语言】c语言常见编程题总结(二)
- linux c 编程实战:文件操作总结(二)
- linux c 编程实战:进程控制总结(二)
- 深入理解C#:编程技巧总结(二)
- 深入理解C#:编程技巧总结(二)
- 深入理解C#:编程技巧总结(二)
- C#(二)总结
- ActiveSync编程总结(二)
- C专家编程(二)
- C专家编程(二)
- C++---编程实战(二)
- C总结复习(二)
- c语言总结(二)
- linux C语言网络编程学习总结<二>
- Windows网络编程总结(二)
- HDU 1875 畅通工程再续
- hdu1596 find the safest road--多源最短路径
- Codeforces Round #346 (Div. 2) B. Qualifying Contest
- BaseAdapter使用与优化
- VS2010+OpenCV的SDI应用——(一)打开图像
- C++泛型编程总结(二)
- 网络:NSURLConnection队列
- POJ-1236-Network of Schools【强连通分量】【缩点】
- 杭电1008
- rails中使用ajax
- 面向对象
- 网络:NSURLConnection 缓存
- 实现多线程有两种方法: Thread类继承和Runnable接口实现
- C/C++—— 一个特别奇怪的C++程序