读入一个正整数 n,计算其各位数字之和,用汉语拼音写出和的每一位数字。
输入格式:
每个测试输入包含 1 个测试用例,即给出自然数 n 的值。这里保证 n 小于 10100。
输出格式:
在一行内输出 n 的各位数字之和的每一位,拼音数字间有 1 空格,但一行中最后一个拼音数字后没有空格。
输入样例:
1234567890987654321123456789
输出样例:
yi san wu
#include <iostream> #include <math.h> #include <algorithm> #include <string.h> using namespace std; char a[110],b[110100]; char s[10][5]={{"ling"},{"yi"},{"er"},{"san"}, {"si"},{"wu"},{"liu"},{"qi"}, {"ba"},{"jiu"}};
int main()
{
cin>>a;
int l=strlen(a);
int sum=0;
for(int i=0;i<l;i++)
{
sum+=(a[i]-'0');
}
int i=0;
while(sum)
{
i++;
b[i]=sum%10;
sum/=10;
}
for(i;i>0;i--)
{
if(i)
cout<<s[b[i]]<<" ";
else
cout<<s[b[i]];
}
return 0;
}
思路:
@一开始,用的int数组读入的输入。。现在想想,,emmm挺傻的,希望以后不要再犯了,想要一位一位的读入要用char数组,(记得减去‘0’);
@一开始,把0~9分成了10种情况,写了10个if语句。。可以直接用二维数组表示要输出的每种字符串(二维的长度设置注意一下,不能太小)(要输出的字符串要放在“ ”里)
@用b数组把sum倒叙储存一下,输出的起始需要注意一下,sum是从b[1]开始录入的,不是b[0];
浙公网安备 33010602011771号