读入一个正整数 n,计算其各位数字之和,用汉语拼音写出和的每一位数字。
输入格式:
每个测试输入包含 1 个测试用例,即给出自然数 n 的值。这里保证 n 小于 。
输出格式:
在一行内输出 n 的各位数字之和的每一位,拼音数字间有 1 空格,但一行中最后一个拼音数字后没有空格。
输入样例:
1234567890987654321123456789
输出样例:
yi san wu
易错点:
①没有注意到和的长度上限是9*100=900,第一次可能会用int,之后改为char
②拼音化的过程中可能顺序颠倒,要注意倒序
解答:(借鉴他人答案)
#include<iostream>
#include<algorithm>
#include<cstring>
using namespace std;
void PinYin(char num[])
{
char ch[][5] ={"ling","yi","er","san","si","wu","liu","qi","ba","jiu"};//创建拼音数组 数组每一行最大长度为5
int len = strlen(num);//strlen()函数必须要char 数组类型,而且计算长度时不带微端"\0"
int sum =0;//计算最后和
for(int i =0; i<len; i++)
{
sum += num[i] - '0';//字符型存储按照asc码
}
int a[3];//用数组记录最后和的结果 ,输入的数小于10的100次方,即一百位,一百位加起来最后结果小于1000,所以存结果的只留三位即可;
int q =0;
//将每一位从地位到高位进行存入数组a
while(sum!=0)
{
a[q] = sum%10;
q++;
sum/=10;
}
for(int j =q-1; j>=0; j--)
{
cout<<ch[a[j]];
if(j!=0)
cout<<" ";
}
cout<<endl;
}
int main()
{
char num[1000];
cin >> num;
PinYin(num);
return 0;
}