读入一个正整数 n,计算其各位数字之和,用汉语拼音写出和的每一位数字。
输入格式:
每个测试输入包含 1 个测试用例,即给出自然数 n 的值。这里保证 n 小于 10^100。
输出格式:
在一行内输出 n 的各位数字之和的每一位,拼音数字间有 1 空格,但一行中最后一个拼音数字后没有空格。
输入样例:
1234567890987654321123456789
输出样例:
yi san wu
总结:
本题字符串的打印符合栈先进后出的特点
获得一段数字的长度可用如下代码:
// An highlighted block
char n[100]= {0};
gets(n);
len = strlen(n);
for(i=0;i<len;i++){
sum+=n[i]-'0';**//注意如何得到数组每一个元素,需要-'0'**
}
本题代码如下:
// An highlighted block
#include<stdio.h>
#include<string.h>
void result(int a){
if(a==0)printf("ling");
if(a==1)printf("yi");
if(a==2)printf("er");
if(a==3)printf("san");
if(a==4)printf("si");
if(a==5)printf("wu");
if(a==6)printf("liu");
if(a==7)printf("qi");
if(a==8)printf("ba");
if(a==9)printf("jiu");
}
int main(){
int i, sum=0, length=0, ans[120]={0};
char c[110];
gets(c);
length=strlen(c);
for(i=0;i<length;i++){
sum+=(c[i]-'0');
}
i=0;
if(sum==0)printf("ling");
while(sum>0){
ans[i++]=sum%10;
sum=sum/10;
}
for(i=i-1;i>=0;i--){
result(ans[i]);
if(i>0)printf(" ");
}
printf("\n");
return 0;
}