题目详情:
读入一个正整数 n,计算其各位数字之和,用汉语拼音写出和的每一位数字。
输入格式:
每个测试输入包含 1 个测试用例,即给出自然数 n 的值。这里保证 n 小于 10
100
。
输出格式:
在一行内输出 n 的各位数字之和的每一位,拼音数字间有 1 空格,但一行中最后一个拼音数字后没有空格。
输入样例:
1234567890987654321123456789
输出样例:
yi san wu
我的思路:首先得到输入字符串的长度,(字符串长度),逐个字符转化成数字求和,(字符转数字)使用二维字符数组(字符数组)来存放拼音,将sum的每一位数字放进一个数组里倒序输出数对应的拼音。
代码:
#include <iostream>
#include <string.h>
using namespace std;
int main()
{
string a;
cin>>a;
int sum=0,l=0;
l=a.length();//c++中获得字符串长度还有size()也可以
for(int i=0;i<l;i++)
{
sum+=a[i]-'0';//将字符串转化成整型
}
char c[][10]={"ling","yi","er","san","si","wu","liu","qi","ba","jiu"};
int d[5]={0},t=0;//用于存放每一位数
while(sum!=0)
{
int b=sum%10;
d[t++]=b;
// cout<<c[b];这里想把每一位数倒着输出出来,可以把他们一一放进数组里面。
sum/=10;
}
printf("%s",c[d[t-1]]);
for(int k=t-2;k>=0;k--){
cout<<" "<<c[d[k]];
}
return 0;
}