题目要求:
读入一个正整数 n,计算其各位数字之和,用汉语拼音写出和的每一位数字。
输入格式:
每个测试输入包含 1 个测试用例,即给出自然数 n 的值。这里保证 n 小于 10100。
输出格式:
在一行内输出 n 的各位数字之和的每一位,拼音数字间有 1 空格,但一行中最后一个拼音数字后没有空格。
输入样例:
1234567890987654321123456789
输出样例:
yi san wu
解题思路:
首先建立一个读音的数组存储各个下标数字对应的读音,将整个读入的字符串的数字分开求和,最后从前往后计算出各个数字的值,打印出所对应的拼音即可。
AC代码:
#include<cstdio>
#include<iostream>
using namespace std;
const int maxn=101;
int main(void){
//先读入一个数
int n;
char pinyin[][5]={"ling","yi","er","san","si","wu","liu","qi","ba","jiu"};
int count=0;
cin>>n;
int num1;
int sum2=0;
int i=0;
int ans[maxn]={0};
//求出他们的数字之和
while(n>0){
num1=n%10;
n=n/10;
count++;
sum2+=num1;
}
//现在有每个数,把他们分开写出对应的值
while(sum2!=0){
ans[i]=sum2%10;
sum2/=10;
i++;
}
for(i=i-1;i>=0;i--){
cout<<pinyin[ans[i]];
if(i>0){
printf(" ");
}
}
printf("\n");
return 0;
}
技术总结:
在整个做题过程中遇到表示多个数据的时候需要空格,一般最后一个数据后面不需要空格,如果输出空格会出现结果错误,常用的方法就是由于是在已知数据个数的时候,通过倒着输出到i>0,来保证最后一位没有空格。