题目:
读入一个正整数 n,计算其各位数字之和,用汉语拼音写出和的每一位数字。
输入格式:
每个测试输入包含 1 个测试用例,即给出自然数 n 的值。这里保证 n 小于 10100。
输出格式:
在一行内输出 n 的各位数字之和的每一位,拼音数字间有 1 空格,但一行中最后一个拼音数字后没有空格。
输入样例:
1234567890987654321123456789
输出样例:
yi san wu
思路:
首先,考虑输入的数字n太大,我们用字符数组来获取这个自然数n;
然后,我们需要定义一个全局的二维数组,用于存放,“ling”,“yi”......“jiu”
注意:PAT不支持gets()的方式输入字符串
#include<stdio.h>
#include<string.h>
#include<iostream>
using namespace std;
/**
**
**@author Fhujinwu
*/
char change[10][5]={"ling","yi","er","san","si","wu","liu","qi","ba","jiu"};
int main()
{
int sum=0,len,num,i;
int ans[100];
char str[1010];//题目说输入一个正整数,n小于10的100次方,太大了,不妨用数组来存放
cin.getline(str,1010); //用这种输入方式,是因为PAT不支持gets()的方式输入
len=strlen(str);
for(i=0;i<len;i++)
sum+=(str[i]-'0');
num=0;
while(sum) //将和的每一位再存放在数组ans中
{
ans[num]=sum%10;
num++;
sum/=10;
}
for(i=num-1;i>=0;i--) //将ans数组中的每一位数组转换为中文
{
printf("%s",change[ans[i]]);
if(i!=0) printf(" ");
else printf("\n");
}
return 0;
}