您的位置:首页 > 编程语言 > C语言/C++

【C++】:C++map的妙用之 计算字符串加和

2016-05-12 22:48 579 查看
[b]*******[/b]写完之后更新[b]*******************[/b]

前言:

在我写完这篇文章之后,我对map有了一个新的理解,那就是对于map型,可以像数组一样的赋值,只不过数组的下标变成了一个数据项而已。

然后就是关于STL方面的,到这篇文章为止,我一共学习了Set以及map,我想queue以及stack还有vector我都不用学了,只是把数据项换了而已,还有把相关的数据项换成了我们想要的东西而已,最后都是用迭代器进行遍历。。。

[b]***************WW*****************************[/b]

题目:

给出字符串92368,求各位之和该怎么求,有的人会用遍历然后变为各位的方法去求,我的博客也已经早就发表过这样的文章,因此我也不再过多介绍了,我这里介绍一种新的方法能够解决这个问题,通过map对应

就是把0-9字符对应到0-9的数字,通过这种对应关系,我们就可以实现这个功能了

下面直接给出代码:

#include <iostream>
#include <map>
#include <string>
using namespace std;
int main(){
map<char,int>  pp;
pp['0'] = 0;
pp['1'] = 1;
pp['2'] = 2;
pp['3'] = 3;
pp['4'] = 4;
pp['5'] = 5;
pp['6'] = 6;
pp['7'] = 7;
pp['8'] = 8;
pp['9'] = 9;
string s = "92368";
int sum = 0;
for(int i=0;i<s.length();i++){
sum += pp[s[i]];
}
cout<<sum<<endl;
}


这样计算出来的sum是28,与我们预期的结果是一样的.测试成功!!!

感觉打开了新世界的大门,感觉非常神奇!!!
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: