C++Primer第五版 练习11.20(解答)
来源:互联网 发布:ubuntu jdk7 64位下载 编辑:程序博客网 时间:2024/05/11 21:33
练习11.20:重写11.1节练习(第376页)的单词统计程序,使用insert代替下标操作。你认为哪个程序更容易编写和阅读?解释原因
答:练习11.20使用insert做法更好,因为尽管代码量变长,但更容易理解
/**C++Primer第五版 *11.3.2节练习 *练习11.20 *问题描述: 练习11.20:重写11.1节练习(第376页)的单词统计程序,使用insert代替下标操作。你认为哪个程序更容易编写和阅读?解释原因*说明:在练习11.3基础上修改*作者:Nick Feng*邮箱:nickgreen23@163.com *//**C++Primer(第五版) *练习11.3*2015/9/22 *问题描述:练习11.3:编写你自己的单词记数程序*说明:照着P375页copy了一遍*作者:Nick Feng*邮箱;nickgreen23@163.com */ #include <iostream>#include <string>#include <map>using namespace std;int main(){ map<string, size_t> word_count; //string到size_t的空map string word; while(cin >> word) { //++word_count[word]; //提取word的计数器并将其加1 ;原来版本 //插入一个元素,关键字等于word,值为1 //若word已经已在word_count中,insert什么也不做 auto ret = word_count.insert({word,1});//下面是四种等价方式,参考P384 // auto ret = word_count.insert(make_pair(word,1)); // auto ret = word_count.insert(pair<string,size_t>(word,1)); // auto ret = word_count.insert(map<string,size_t>::value_type(word,1)); if(!ret.second) ++ret.first -> second; } for(const auto &w : word_count) cout << w.first << " occurs " << w.second << ((w.second > 1) ? " times" : " time") << endl; return 0;}
0 0
- C++Primer第五版 练习11.20(解答)
- C++Primer 第五版 练习9.43 解答
- C++Primer 第五版 练习10.12解答
- C++Primer第五版 练习10.32解答
- C++Primer第五版 1.2节练习(解答)
- C++Primer第五版 练习11.3(解答)
- C++Primer第五版 练习11.4(解答)
- C++Primer第五版 练习11.7(解答)
- C++Primer第五版 练习11.8(解答)
- C++Primer第五版 练习11.9(解答)
- C++Primer第五版 练习11.10(解答)
- C++Primer第五版 练习11.11(解答)
- C++Primer第五版 11.2.3节练习(解答)
- C++Primer第五版 练习11.12(解答)
- C++Primer第五版 练习11.13(解答)
- C++Primer第五版 练习11.14(解答)
- C++Primer第五版 练习11.16(解答)
- C++Primer第五版 练习11.17(解答)
- 【leetcode】Merge k Sorted Lists(TLE)
- C++Primer第五版 11.3.2节练习
- iOS 9 适用 修改状态栏
- 【NPOI】类库
- hpux DRD克隆软件版本升级说明
- C++Primer第五版 练习11.20(解答)
- ios工程如何添加pch文件
- Linux 下 MQ 的安装
- C++Primer第五版 练习11.23(解答)
- java监控工具备忘
- Code Forces 582 A. GCD Table(数论)
- mongodb nodeJs聚合查询
- Linux 下 NFS 服务器的安装与配置
- 天声人語 20151009 ペンギン100年