读入一个正整数 n,计算其各位数字之和,用汉语拼音写出和的每一位数字。
输入格式:
每个测试输入包含 1 个测试用例,即给出自然数 n 的值。这里保证 n 小于 10100。
输出格式:
在一行内输出 n 的各位数字之和的每一位,拼音数字间有 1 空格,但一行中最后一个拼音数字后没有空格。
输入样例:
1234567890987654321123456789
输出样例:
yi san wu
这个题目通过分析可知,首先要做的就是求出n每位上的数字之和sum,因为n的上限极其大,所以不能通过int、long等直接存入,需要将n当作字符数组(字符串)处理。又因为我们的目的只是求出sum,和n的具体值没有什么关系,所以没必要单独定义一个数组把n的每一位都存入,只需要通过getchar()函数一个一个地读取、累加,然后弃之即可。‘s’-'0’即为s的数值。
由题目知n<10100,当n<10时n为一位数,当n<102时n为两位数……所以当n<10100时n最多为100位数,且最大为999……9(100个9),其sum为900,所以存放sum每位上的数字的数组长度为3就足够,即代码中的#define max 3以及int d[max]。
定义一个常量二维字符数组(字符串数组)pinyin,将0~9的拼音依次存入,这样数组下标恰好与数值及拼音相对应,非常方便。
//1002 写出这个数(20分)
//Yuanxing Xu
#include
#define max 3
using namespace std;
const char* pinyin[] = {
"ling","yi","er","san","si","wu","liu","qi","ba","jiu"};
int main() {
char c;
int sum=0;
while((c=getchar())!='\n')
sum += c-'0';
//cout<
int i,d[max];
for(i=0;i<max&&sum!=0;i++){
d[i]=sum%10;
sum/=10;
}
i--;
for(;i>=0;i--){
if(i==0)
cout<<pinyin[d[i]]<<endl;
else
cout<<pinyin[d[i]]<<" ";
}
return 0;
}
//1002 写出这个数(20分)
//Yuanxing Xu
#include
#define max 3
const char* pinyin[] = {
"ling","yi","er","san","si","wu","liu","qi","ba","jiu"};
int main() {
char c;
int sum=0;
while((c=getchar())!='\n')
sum += c-'0';
//printf("%d\n",sum);
int i,d[max];
for(i=0;i<max&&sum!=0;i++){
d[i]=sum%10;
sum/=10;
}
i--;
for(;i>=0;i--){
if(i==0)
printf("%s\n",pinyin[d[i]]);
else
printf("%s ",pinyin[d[i]]);
}
return 0;
}