(pat乙级1002)
读入一个正整数 n,计算其各位数字之和,用汉语拼音写出和的每一位数字。
输入格式:
每个测试输入包含 1 个测试用例,即给出自然数 n 的值。这里保证 n 小于 10100。
输出格式:
在一行内输出 n 的各位数字之和的每一位,拼音数字间有 1 空格,但一行中最后一个拼音数字后没有空格。
输入样例:
1234567890987654321123456789
输出样例:
yi san wu
c++代码:
#include<iostream>
#include<sstream>
using namespace std;
int main(){
string a;
cin>>a;
int l=a.length();
int s=0; //s保存输入的n的各个位数字之和
string word[10]={"ling","yi","er","san","si","wu","liu","qi","ba","jiu"};
for(int i=0;i<=l-1;i++){
s=s+a[i]-'0';
}
stringstream ss; //借助ss把long long的s转化为string类型的ns
ss<<s;
string ns;
ss>>ns;
int ll=ns.length();
for(int i=0;i<ll-1;i++){
cout<<word[ns[i]-'0']<<" "; //按位输出ns的各位数字拼音
}
cout<<word[ns[ll-1]-'0'];
return 0;
}
注意:借用sstream头文件下的stringstream类来进行任意类型和string型间的转化,把long long型的各位数字和转化为string,按位输出拼音