读入一个正整数 n,计算其各位数字之和,用汉语拼音写出和的每一位数字。
输入格式:
每个测试输入包含 1 个测试用例,即给出自然数 n 的值。这里保证 n 小于 10100。
输出格式:
在一行内输出 n 的各位数字之和的每一位,拼音数字间有 1 空格,但一行中最后一个拼音数字后没有空格。
输入样例:
1234567890987654321123456789
输出样例:
yi san wu
#include <iostream>
using namespace std;
void readout(int x)
{
if(x==0)cout<<"ling";
else if(x==1)cout<<"yi";
else if(x==2)cout<<"er";
else if(x==3)cout<<"san";
else if(x==4)cout<<"si";
else if(x==5)cout<<"wu";
else if(x==6)cout<<"liu";
else if(x==7)cout<<"qi";
else if(x==8)cout<<"ba";
else if(x==9)cout<<"jiu";
}
int main()
{
char a[100000];
cin>>a;
int sum=0;
for(int i=0;a[i]!='\0';i++)
sum+=static_cast<int>(a[i])-48;
//cout<<sum<<endl;
int depart[10000];
int x=0;
while(sum!=0)
{
depart[++x]=sum%10;
sum/=10;
}
//for(int i=1;i<=x;i++)
//cout<<depart[i]<<" ";
for(int i=x;i>1;i--)
{
readout(depart[i]);
cout<<" ";
}
readout(depart[1]);
return 0;
}
一道枚举式的实现过程~