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

*******写完之后更新*******************
前言:
在我写完这篇文章之后,我对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,与我们预期的结果是一样的.测试成功!!!

感觉打开了新世界的大门,感觉非常神奇!!!

你可能感兴趣的:(String,遍历,博客,C语言,地图)