天梯赛备赛:L1-007 念数字 (map使用)

输入一个整数,输出每个数字对应的拼音。当整数为负数时,先输出fu字。十个数字对应的拼音如下:

0: ling
1: yi
2: er
3: san
4: si
5: wu
6: liu
7: qi
8: ba
9: jiu

输入格式:

输入在一行中给出一个整数,如:1234。

提示:整数包括负数、零和正数。
输出格式:

在一行中输出这个整数对应的拼音,每个数字的拼音之间用空格分开,行末没有最后的空格。如 yi er san si。
输入样例:

-600

输出样例:

fu liu ling ling

个人分析:
我个人觉得我还是暴力求的,先将每个数字对应的拼音放入map中,然后进行find查找 如果没找到就输出fu 找到了输出对应的拼音 但是题目要求是最后没空格 所以我们对于最后一个特殊处理(单独输出) 然后就能AC了 也没有坑点~

具体代码如下:
AC

#include<iostream>
#include<cstring>
#include<string>
#include<map>
using namespace std;
map<char,string> mp;
map<char,string>:: iterator it;
int main()
{
    mp.insert(make_pair('0',"ling"));
    mp.insert(make_pair('1',"yi"));
    mp.insert(make_pair('2',"er"));
    mp.insert(make_pair('3',"san"));
    mp.insert(make_pair('4',"si"));
    mp.insert(make_pair('5',"wu"));
    mp.insert(make_pair('6',"liu"));
    mp.insert(make_pair('7',"qi"));
    mp.insert(make_pair('8',"ba"));
    mp.insert(make_pair('9',"jiu"));
    string str;
    while(cin>>str)
    {
        for(int i=0;i<str.length()-1;i++)
        {
            it=mp.find(str[i]);
            if(it==mp.end())
            {
                cout<<"fu ";
            }
            else
            {
                cout<<it->second<<" ";
            }
        }
        it=mp.find(str[str.length()-1]);
        cout<<it->second;
        cout<<endl;
    }
    return 0;
}

学如逆水行舟,不进则退

猜你喜欢

转载自blog.csdn.net/weixin_42429718/article/details/88329948