读入一个自然数n,计算其各位数字之和,用汉语拼音写出和的每一位数字。
输入格式:每个测试输入包含1个测试用例,即给出自然数n的值。这里保证n小于10100。
输出格式:在一行内输出n的各位数字之和的每一位,拼音数字间有1 空格,但一行中最后一个拼音数字后没有空格。
输入样例:1234567890987654321123456789输出样例:
yi san wu
[EASY] 把每位数字放入数组求sum 在求sum的每一位 按要求输出
#include<iostream>
#include<cstdio>
#include<cstring>
#include<cstdlib>
#include<cmath>
#include<algorithm>
#include<set>
#include<queue>
using namespace std;
int main()
{
int sum=0,c,b[120];
string a;
getline(cin,a);
int len=a.size();
for(int i=0;i<len;i++)
{
sum+=a[i]-48;
}
int j=0;
while(sum)
{
c=sum%10;
b[j]=c;
j++;
sum/=10;
}
for(int i=j-1;i>=0;i--)
{
if(b[i]==1) printf("yi");
else if(b[i]==2) printf("er");
else if(b[i]==3) printf("san");
else if(b[i]==4) printf("si");
else if(b[i]==5) printf("wu");
else if(b[i]==6) printf("liu");
else if(b[i]==7) printf("qi");
else if(b[i]==8) printf("ba");
else if(b[i]==9) printf("jiu");
else printf("ling");
if(i!=0) printf(" ");
}
return 0;
}