发表在专栏“PAT乙级题目详解”,并在持续更新中。
https://blog.csdn.net/column/details/23947.html
读入一个自然数n,计算其各位数字之和,用汉语拼音写出和的每一位数字。
输入格式:每个测试输入包含1个测试用例,即给出自然数n的值。这里保证n小于10^100^。
输出格式:在一行内输出n的各位数字之和的每一位,拼音数字间有1 空格,但一行中最后一个拼音数字后没有空格。
输入样例:
1234567890987654321123456789
输出样例:
yi san wu
分析:
这是典型的字符串和数字转化的问题。
1.虽然题干中写的是输入自然数n,但是在写代码的时候定义n为整型是不对的,因为把整型n的每一位相加,首先需要得到每一位的值,从数字中得到每一位,很麻烦。所以在写代码的时候应该直接定义n位char型的数组。遍历数组中的每一个字符,使用其ASCII运算,得到每一位相加的和。
for (int i = 0; i < strlen(c); i++)
{
n = n + c[i] - '0';
}
2.把得到的结果转化成拼音,以135为例。
先除10取余,得到最低位,然后再除10.
while (n!=0)
{
a[t] = n % 10;
n = n / 10;
t++;
}
a[0] = 135%10 = 5,n = 135/10 = 13, t =1;
a[1] = 13%10 = 3,n = 13/10 = 1, t =2;
a[2] = 1%10 = 1,n = 1/10 = 0, t =3;
完整代码;
#include
#include
#include
using namespace std;
int main()
{
//输入字符串
char c[101];
char pinyin[][10] = { "ling", "yi", "er", "san", "si", "wu", "liu", "qi", "ba", "jiu" };
int a[10];
int i, n = 0, t = 0;
cin >> c;//输入字符串
for (int i = 0; i < strlen(c); i++)
{
n = n + c[i] - '0';
}
while (n!=0)
{
a[t] = n % 10;
n = n / 10;
t++;
}
printf("%s", pinyin[a[t - 1]]);
for (i = t - 2; i >= 0; i--)
{
printf(" %s", pinyin[a[i]]);
}
return 0;
}