1002 写出这个数 (20分)

读入一个正整数 n,计算其各位数字之和,用汉语拼音写出和的每一位数字。

输入格式:
每个测试输入包含 1 个测试用例,即给出自然数 n 的值。这里保证 n 小于 10100

输出格式:
在一行内输出 n 的各位数字之和的每一位,拼音数字间有 1 空格,但一行中最后一个拼音数字后没有空格。

输入样例:

1234567890987654321123456789

输出样例:

yi san wu

思路分析

对输入(字符串形式)的数字,遍历每一位,统计其各位数字之和。
方法一、可以通过对sum%10将其余数压栈,sum/=10;最后将栈中的余数为下标的拼音元素输出即可得到该数的拼音。
方法二、直接通过stringstream将数字转成字符串,最后输出以字符串的每个位与字符‘0’的差为下标的拼音元素即可得到该数的拼音。

注意点

  1. s.top()是取栈顶元素,并不会弹栈,要调用s.pop();进行弹栈。

代码

#include 
#include 
#include 
#include
using namespace std;

int main()
{
    string pinyin[10] = {"ling","yi","er","san","si","wu",
                         "liu","qi","ba","jiu"};
    string str;
    int sum = 0;
    stack<int> s;
    cin>>str;
    //读入一个正整数 n,计算其各位数字之和
    for(int i=0;i<str.length();i++){
        sum += str[i] - '0';
    }
    
    //方法一
    /*
    while(sum!=0){
        //不断求余,然后压栈
        s.push(sum%10);
        sum/=10;
    }
    while(!s.empty()){
        if(s.size()>1){
            cout<

    //方法二
    stringstream ss;
    ss<<sum;//将数字输入到字符串流中
    ss>>str;//然后输出为字符串
    for(int i=0;i<str.length();i++){
        if(i!=0)
            cout<<" ";
        cout<<pinyin[str[i]-'0'];
    }
    cout<<endl;
    return 0;
}

你可能感兴趣的:(PAT,算法,c++)