C++ Primer :第十章 :泛型算法之再探迭代器以及其他算法
除了为每个容器定义的迭代器之外,标准库在头文件<iterator>还定义了额外集中迭代器, 包括:
- 插入迭代器,这些迭代器被绑定到一个容器上,可以向容器插入元素。
- 流迭代器, 这些迭代器被绑定到输入或输出流上,可以遍历所关联的IO流
- 反向迭代器,这些迭代器向后而不是向前移动,除了forward_list之外的标准库容器都有反向迭代器。
- 移动迭代器,这些专用得对得起不是拷贝而是移动其中的元素。
插入迭代器
- it = t 在it指定的位置插入值t
- *it, ++it, --it
有三种插入迭代器:
- back_inserter 创建一个使用push_back的迭代器。
- front_inserter创建一个使用push_front的迭代器。
- inserter创建一个使用insert的迭代器。此函数接受第二个参数,这个参数必须是一个指向给定容器的迭代器。元素被插入到指定的迭代器所表示的元素之前。
- *it = val;
效果和下面的代码一样:
- it = c.insert(it, val);
- ++it; // 递增it使它指向原来的元素
而front_inserter生成迭代器的行为和inserter不一样,front_inserter会将传入的元素逆序插入到容器内:
- list<int> lst1 = {1, 2, 3, 4};
- list<int> lst2, lst3;
- copy(lst.begin(), lst.end(), front_inserter(lst2));
- copy(lst.begin(), lst.end(), inserter(lst3, llst3.begin()));
我们如果输出lst2和lst3的内容,则可以看到lst2 = 4, 3, 2, 1 而lst3 = 1, 2, 3, 4
iostream迭代器
1. istream_iterator操作
- // 从cin读取string
- istream_iterator<string> isiter(cin);
- // 从 file读取string
- ifstream ifs("file");
- istream_iterator<string> isiter1(ifs);
我们还可以默认初始化一个流迭代器,这样就创建了一个尅当做尾后值使用的迭代器。
- vector<int> vec;
- istream_iterator<int> in_iter(cin);
- istream_iterator<int> end; // istream_iterator尾后迭代器
- while(in_iter != end)
- vec.push_back(*in_iter++);
2.ostream_iterator操作
- ostream_iterator<int> out(cout, " ");
- for (auto const e : vec)
- *out ++ = e;
- cout << endl;
这个程序会将vec中元素输出,而且元素之间都用" " 隔开。
反向迭代器
- vector<int> vec{0, 1, 2, 3, 4, 5};
- for (auto riter = vec.rbegin(); riter != vec.rend(), ++riter)
- cout << *riter << endl;
我们还可以将一个容器的元素从递增排序变为递减顺序:
- // 递增顺序
- sort(vec.begin(), vec.end());
- // 递减顺序
- sort(vec.rbegin(), vec.rend());
从一个string中打印第一个单词,假定string的单词之间都用逗号隔开:
- string line{"FIRST", "MIDDLE", "LAST"};
- auto comma = find(line.begin(), line.end(), ",");
- cout << string(line.cbegin(), comma);
如果希望打印最后一个单词,我们可以使用反向迭代器:
- auto rcomma = find(line.rbegin(), line.rend(), ",");
- cout << string(line.crbegin(), rcomma);
- cout << string(rcomma.base(), line.cend());
- find(beg, end, val); // 查找val第一次出现的位置
- find_if(beg, end, pred); // 查找第一个使得谓词pred为真的元素
- reverse(beg, end); // 反转范围中的元素的顺序
- reverse(beg, end, dest); // 将元素按逆序拷贝到dest
- //从v中删除奇数元素
- remove_if(v.begin(), v.end(), [] (int i) { return i % 2; });
- // 将偶数元素从v拷贝到v2,v不变。
- remove_copy_if(v.begin(), v.end(), back_inserter(v2), [] (int i) { return i % 2;});
- lst.merge(lst2); 将来自lst2的元素合并入lst,lst和lst2都必须是有序的
- lst.merge(lst2, comp); 元素将从lst2中删除,在合并之后,lst2变为空,第一个版本使用 < 运算符, 第二个版本使用给定的比较操作
- lst.remove(val); 调用erase删除掉与给定值相等或令一元谓词为真的每个元素
- lst.remove_if(pred);
- lst.reverse(); 反转lst中元素的顺序
- lst.sort(); 使用< 或给定比较操作排序元素
- lst.sort(comp);
- lst.unique(); 调用erase删除用一个值的连续拷贝,第一个版本使用==, 第二个版本使用给定的二元谓词。
- lst.unique(pred);
链表类型还定义了splice成员算法
- // lst.splice(args)或flst.splice_after(args)
- (p, lst2) p是一个指向lst中元素的迭代器,或一个指向flst首前位置的迭代器。
- 函数将lst2所有元素移动到lst中p之前的位置或是flst中p之后的位置。将元素从lst2中删除,lst2的类型必须与lst或flst相同,且不能是同一个链表
- (p, lst2, p2) p2是一个指向lst2中位置的有效迭代器,将p2指向的元素移动到lst中,或将p2之后的元素移动到flst中,lst2可以使与lst或flst相同的链表
- (p, lst2, b, e) b和e必须表示lst2中的合法范围,将给定范围中的元素从lst2移动到lst或flst。lst2与lst(或flst)可以是相同的链表,但p不能指向给定范围中的元素
C++ Primer :第十章 :泛型算法之再探迭代器以及其他算法的更多相关文章
- C++ Primer : 第十章 : 泛型算法 之 只读、写和排序算法
大多数算法都定义在<algorithm>头文件里,而标准库还在头文件<numeric>里定义了一组数值泛型算法,比如accumulate. ● find算法,算法接受一对迭代 ...
- C++ Primer : 第十章 : 泛型算法 之 lambda表达式和bind函数
一.lambda表达式 lambda表达式原型: [capture list] (parameter list) -> retrue type { function body } 一个lambd ...
- 【C++ Primer 第10章】再探迭代器
反向迭代器 • 反向迭代器就是在容器中从尾元素向首元素反向移动的迭代器.对于反向迭代器,递增(以及递减)操作的含义会颠倒过来. • 递增一个反向迭代器(++it)会移动到前一个元素:递减一迭代器(-- ...
- 【C++ Primer | 10】再探迭代器
插入迭代器 1. 测试代码: #include<iostream> #include<vector> #include<list> #include<iter ...
- 10.4 再探迭代器-插入/IO/反向
10.4.1 插入迭代器 插入迭代器接受一个容器,生成一个迭代器,通过向该迭代器赋值可以实现向容器添加元素 (1)back_inserter: 接受一个参数, 示例: auto iter = back ...
- 【C++ Primer | 10】泛型算法
#include<iostream> #include<algorithm> #include<vector> #include<string> #in ...
- C++ Primer 学习笔记_43_STL实践与分析(17)--再谈迭代器【中】
STL实践与分析 --再谈迭代器[中] 二.iostream迭代[续] 3.ostream_iterator对象和ostream_iterator对象的使用 能够使用ostream_iterator对 ...
- C++ Primer 学习笔记_44_STL实践与分析(18)--再谈迭代器【下】
STL实践与分析 --再谈迭代器[下] 三.反向迭代器[续:习题] //P355 习题11.19 int main() { vector<int> iVec; for (vector< ...
- C++Primer 第十章
//1.标准库算法不仅可以应用于容器,还可以应用于内置数组,指针. //2.大多数算法都定义在头文件algorithm中.标准库还在头文件numeric中定义了一组数值泛型算法. //3.算法本身不会 ...
随机推荐
- Android双击返回按钮退出程序
//双击退出事件 @Override public boolean onKeyDown(int keyCode, KeyEvent event) { if(keyCode == KeyEvent.KE ...
- HDU 4085 斯坦纳树
题目大意: 给定无向图,让前k个点都能到达后k个点(保护地)中的一个,而且前k个点每个需要占据后k个中的一个,相互不冲突 找到实现这个条件达到的选择边的最小总权值 这里很容易看出,最后选到的边不保证整 ...
- Android 获取网络状态
1.检测网络是否可用 public boolean isNetWorkConnected() { ConnectivityManager cm = (ConnectivityManager)getSy ...
- (转载)Htmlparser Filter 简要归纳
1 . 逻辑关系:与或非 AndFilter() Creates a new instance of an AndFilter. AndFilter(NodeFilter[] pr ...
- 教学目标的表述方式──行为目标的ABCD表述法
教学目标应规定学生在教学活动结束后能表现出什么样的学业行为,并限定学生学习过程中知识.技能的获得和情感态度发展的层次.范围.方式及变化效果的量度.对每节课教学目标的准确表述,可以充分发挥教学目标在教学 ...
- 摘自:java夜未眠之java学习之道
目前Java可以说是产业界和学术界最热门的语言,许多读者都很急切想把Java学好.除非是武侠小说中的运功传送内力的方式,否则花上一段时间苦学是免不了的.花时间,不打紧,就是怕方法错误,事倍功半.我认为 ...
- windows8.1 plsql连接oracle
http://pan.baidu.com/share/link?shareid=3782452820&uk=3557941237 http://pan.baidu.com/share/link ...
- linux 快速安装mysql
yum list | grep mysqlyum install -y mysql-server mysql mysql-devel service mysqld startmysqladmin -u ...
- select multiple images in Android Gallery
http://stackoverflow.com/questions/18520976/all-properties-of-intent-putextra-to-crop-image-in-andro ...
- 2016 - 1 - 22 HTTP(二)
一: 发送HTTP请求的方法 1.在HTTP/1.1中规定了8种发送请求的方法: 2.发送请求时需要参数,比如POST中的账号密码 二:POST与GET的对比 1.GET与POST的主要区别表现在数据 ...