题目
读入一个正整数 n,计算其各位数字之和,用汉语拼音写出和的每一位数字。
输入格式:
每个测试输入包含 1 个测试用例,即给出自然数 n 的值。这里保证 n 小于 10^100。
输出格式:
在一行内输出 n 的各位数字之和的每一位,拼音数字间有 1 空格,但一行中最后一个拼音数字后没有空格。
输入样例:
1234567890987654321123456789
输出样例:
yi san wu
思路
1.定义所输入的字符数组a[100];
2.定义一个拼音字符数组pyChar[10][5];
3.字符串遍历:字符串存储的时候以’\0’结尾,字符串for循环结束条件for(int i=0;a[i]!=’\0’;i++);
4.在ACSII码表中,字符‘0’的十进制值是48,所以将字符型转化为整型时,需原字符减去‘0’;
5.考虑sum的位数。
代码
#include <stdio.h>
int main()
{
char a[100];
char pyChar[10][5] = {"ling","yi","er","san","si","wu","liu","qi","ba","jiu"};
int sum = 0;
scanf("%s",a);
for(int i = 0;a[i] != '\0';i++){
sum += a[i] - '0';
}
if(sum / 100 != 0)
printf("%s %s %s",pyChar[sum / 100],pyChar[(sum / 10) % 10],pyChar[sum % 10]);
else if(sum / 10 != 0)
printf("%s %s",pyChar[sum / 10],pyChar[sum % 10]);
else printf("%s",pyChar[sum]);
}
总结
char* 和 char[ ]的区别:
对于char * a="string1"与char b[ ]=“string2”;
其中a指向的是一个字符串常量,即指向的内存区域只读;
b始终指向它所代表的数组在内存中的位置,始终可写。