*******写完之后更新*******************
前言:
在我写完这篇文章之后,我对map有了一个新的理解,那就是对于map型,可以像数组一样的赋值,只不过数组的下标变成了一个数据项而已。
然后就是关于STL方面的,到这篇文章为止,我一共学习了Set以及map,我想queue以及stack还有vector我都不用学了,只是把数据项换了而已,还有把相关的数据项换成了我们想要的东西而已,最后都是用迭代器进行遍历。。。
***************WW*****************************
题目:
给出字符串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,与我们预期的结果是一样的.测试成功!!!
感觉打开了新世界的大门,感觉非常神奇!!!