1002 写出这个数 (20 分)
读入一个正整数 n,计算其各位数字之和,用汉语拼音写出和的每一位数字。
输入格式:
每个测试输入包含 1 个测试用例,即给出自然数 n 的值。这里保证 n 小于 10100。
输出格式:
在一行内输出 n 的各位数字之和的每一位,拼音数字间有 1 空格,但一行中最后一个拼音数字后没有空格。
输入样例:
1234567890987654321123456789
输出样例:
yi san wu
写个题叭,不难。但也想了一会,毕竟我代码能力超级弱。
看题目,给的样例,这么长的数字肯定是字符串输入。要求计算每位数字之和,然后用拼音输出,那么就是定义一个二维的字符串数组,把拼音写进去,再定义一个一维的字符串数组,把输入放进去,然后用strlen求出长度,再用for循环,求出每一位数字,然后用 -‘0’ ,将字符转化成数字,用一个简单的求和,可以算出135,再用一个while循环,求出sum的位数, 再用一个for循环算出每一位数字k,这样就可以输出每个k对应的str[k]了,但是这样输出来的是倒着的,所以,再用一个二维数组,反向存一下,就可以输出了。
#include <stdio.h>
#include <string.h>
int main(){
char s[1000];
int a[100];
int mm=0;
char str[10][10]={"ling","yi","er","san","si","wu","liu","qi","ba","jiu"};
char sr[10][10];
scanf("%s",s);
int len=strlen(s);
int sum=0,n;
for(int i=0;i<len;i++){
n=s[i]-'0';
sum=sum+n;
}
printf("sum:%d\n",sum);
int sm=0;
sm=sum;
int m=0,k=0;
while(sm){
m++;
sm=sm/10;
}
mm=m;
printf("m:%d\n",m);
for(int i=1;i<=m;i++){
k=sum%10;
sum=sum/10;
strcpy(sr[mm--],str[k]);
}
for(int i=1;i<m;i++){
printf("%s*",sr[i]);
}
printf("%s",sr[m]);
}