读入一个正整数 n,计算其各位数字之和,用汉语拼音写出和的每一位数字。
输入格式:
每个测试输入包含 1 个测试用例,即给出自然数 n 的值。这里保证 n 小于 10^100 。
输出格式:
在一行内输出 n 的各位数字之和的每一位,拼音数字间有 1 空格,但一行中最后一个拼音数字后没有空格。
输入样例:
1234567890987654321123456789
输出样例:
yi san wu
注意分析题目:
1、用拼音写出每一位数字,就是说用拼音来表示汉字(则意味着yi er san si wu liu qi ba jiu 分别对应123456789),把拼音存在数组里面,然后从键盘上输入的数字是按照字符串来接收的,要装换成数字然后累加起来number=number+c[i]-‘0’;(字符和汉字之间的转换,字符减去“0”的ASCLL码值就是数字。
2、然后模除取余找到最后一个数字,整除缩小范围,把得到的数字存贮起来,{注意:我存的时候是从低位往高位存储的,所以打印的时候要从高位到低位打印},然后到拼音数组里面找到该数字的拼音,打印出来。
3、要注意打印的格式,开头没有空行,printf函数不默认换行,最后输出也没有空格;
#include<stdio.h>
#include<string.h>
int main(){
char c[100];
char pingyin[][9]={"ling","yi","er","san","si","wu","liu","qi","ba","jiu"};//123456789
int numberstore[10];
int i,number=0,index=0;
gets(c);//输入那一串数字 ,但是是把数字当成字符类型读入
for(i=0;i<strlen(c);i++){
number=number+c[i]-'0';//当成字符类型读入时转换成数字类型要减去0的ASCII码,累加
}
while(number!=0){//把累加后的数字存到数组a中
numberstore[index]=number%10;
number=number/10;
index++;
}
//在一行内输出 n 的各位数字之和的每一位,拼音数字间有 1 空格,但一行中最后一个拼音数字后没有空格。
printf("%s",pingyin[numberstore[index-1]]);
for(i=index-2;i>=0;i--){
printf(" %s",pingyin[numberstore[i]]);
}
return 0;
}
让我奇怪的是同样的代码提交2次耗时竟然相差这么大,额