C++Primer第五版 11.3.5节练习
来源:互联网 发布:微信扫码登录源码 编辑:程序博客网 时间:2024/06/05 15:36
练习11.27:对于什么问题你会使用count来解决?什么时候你又会选择find呢?
答:如果只是关心元素是否在容器中,find可能是最佳选择。如果需要进行统计等更多的工作,count是不错的选择。
练习11.28:对一个string到int的vector的map,定义并初始化一个变量在其上调用find所返回的结果。
map<string,vector<int>> m;
/**2015/10/10 *C++Primer第五版*11.3.5节练习 *练习11.28*问题描述:练习11.28:对一个string到int的vector的map,定义并初始化一个变量在其上调用find所返回的结果。说明: 按着题目要求做 *作者:Nick Feng*邮箱:nickgreen23@163.com */ #include <iostream>#include <map>#include <string>#include <vector>using namespace std;int main(){ vector<int> vec = {1,2,3,4,5}; vector<int> vec2 = {6,7,8,9,10}; string s = "T"; string s1 = "B"; map<string,vector<int>> m = {{s,vec},{s1,vec2}}; //初始化迭代器it //将关键字为“T”所在的迭代器赋值给it map<string,vector<int>>::iterator it = m.begin(); it = m.find("T"); //打印 cout << (*it).first << " "; for(auto &i : (*it).second) cout << i << " "; cout << endl; return 0; }
练习11.29:如果给定的关键字不在容器中,upper_bound,lower_bound和equal_range分别返回什么?
答:如果关键字不在容器中,则lower_bound会返回关键字的第一个安全插入点—不影响容器中元素顺序的插入位置。upper_bound返回尾后迭代器。equal_range中,如果未找到匹配元素,则两个迭代器都指向关键字可以插入的位置。
练习11.30:对于本节最后一个程序中的输出表达式,解释运算对象pos.first->second的含义。
答:就是打印每个题目
练习11.31:编写程序,定义一个作者及其作品的multimap。使用find在multimap中查找一个元素并用erase删除它。确保你的程序在元素不在map中时也能正常运行。练习11.32:使用上一题定义的multimap编写一个程序,按字典打印作者列表和他们的作品。
练习11.32:使用上一题定义的multimap编写一个程序,按字典序打印作者列表和他们的作品
练习11.31-32
/**2015/10/10 *C++Primer第五版*11.3.5节练习 *练习11.28*问题描述:练习11.31:编写程序,定义一个作者及其作品的multimap。使用find在multimap中查找一个元素并用erase删除它。确保你的程序在元素不在map中时也能正常运行。练习11.32:使用上一题定义的multimap编写一个程序,按字典打印作者列表和他们的作品。说明: 按着题目要求做 *作者:Nick Feng*邮箱:nickgreen23@163.com */ #include <iostream>#include <string>#include <map>using namespace std;int main(){ multimap<string,string> m = {{"John","Happy Time"},{"Lucy","Tom's Hourse"},{"Jim","Young boy"}}; for(auto &m1 : m) cout << m1.first << " " << m1.second << endl; cout << "plesae input name who you want to erase!" << endl; string name; while(cin >> name) { if(m.find(name) != m.end()) m.erase("John"); else { cout << "Not found!Can not erase" << endl; } } for(auto &m1 : m) cout << m1.first << " " << m1.second << endl; return 0; }
0 0
- C++Primer第五版 11.3.5节练习
- C++Primer 第五版 1.1节练习
- C++Primer第五版 1.3节练习
- C++Primer第五版 1.6节练习
- C++Primer第五版 2.4节练习
- C++Primer第五版 3.1节练习
- C++Primer第五版 4.2节练习
- C++Primer第五版 4.3节练习
- C++Primer第五版 4.4节练习
- C++Primer第五版 4.6节练习
- C++Primer第五版 4.7节练习
- C++Primer第五版 4.8节练习
- C++Primer第五版 4.9节练习
- C++Primer第五版 4.5节练习
- C++Primer第五版 5.1节练习
- C++Primer第五版 5.2节练习
- C++Primer第五版 6.1节练习
- C++Primer第五版 6.4节练习
- Qt5.5在ubuntu下解决 GL/gl.h: No such file or directory 与 cannot find -lGL
- NLTK学习一
- UVa 620 Cellular Structure
- 1036. Boys vs Girls
- 带层级关系的递归遍历目录内容
- C++Primer第五版 11.3.5节练习
- 插件开发技术说明(17)---应用CRUD开发模式范例
- Android Socket 使用(客户端和服务端)
- iOS开发中的字典转模型应用
- debian 源
- 02-线性结构1 一元多项式的乘法与加法运算
- 伪任意地址HOOK类
- 无敌代码
- set用法1