题目:
读入一个自然数n,计算其各位数字之和,用汉语拼音写出和的每一位数字。
输入格式:每个测试输入包含1个测试用例,即给出自然数n的值。这里保证n小于10100。
输出格式:在一行内输出n的各位数字之和的每一位,拼音数字间有1 空格,但一行中最后一个拼音数字后没有空格。
输入样例:1234567890987654321123456789
输出样例:
yi san wu
用到的知识:1、字符与数字的相互转换,2、整数逐位存储到数组
首先用字符串读取大整数,然后累加大整数的每一位,用一个数组存储累加和,最后逐位输出。
注意:本题要求格式输出,末尾不得有空格。所以最后处理时,先输出第一位,剩下的按"空格—值"的格式输出
#include<iostream>
#include<cstring>
using namespace std;
int main()
{
char n[10101];
scanf("%s",&n);//将大数存储在字符数组中
int mei[1000]={0};//存储相加后的每一位数字
int s=strlen(n);//获取大数的位数
string show[10]={"ling","yi","er","san","si","wu","liu","qi","ba","jiu"};
int m=0;//每一位相加和
int num=0;//逐位相加
for(int i=0;i<s;i++) //对每位求和
{
m+=n[i]-'0';
}
while(m>0)//按个十百……给mei[]数组每位数字赋值
{
num++;
mei[num]=m%10;
m/=10;
}
cout<<show[mei[num]];//首先输出第一位,之后的每位输出空格加数字
for(int i=num-1;i>0;i--)
{
cout<<" "<<show[mei[i]];
}
return 0;
}