?题目描述:
读入一个正整数?n,计算其各位数字之和,用汉语拼音写出和的每一位数字。
输入格式:
每个测试输入包含 1 个测试用例,即给出自然数?n?的值。这里保证?n?小于?10^100。
输出格式:
在一行内输出?n?的各位数字之和的每一位,拼音数字间有 1 空格,但一行中最后一个拼音数字后没有空格。
输入样例:
1234567890987654321123456789
结尾无空行
输出样例:
yi san wu
结尾无空行
题目的关键在于数据输入如何存储以及字母间的空格的处理。
数据采用string类型存储,将字符数组的各个位相加即可得到总和。注意数字在数字中一ASCII码存储,要减去相应数值。
对于字符间空格的处理,首先利用getCount函数获取相加和s的位数count,在每次输出一个拼音之后都做判断,输出次数是否已经达到count,未达到则输出空格。
程序源码:
#include <iostream>
#include <string>
using namespace std;
//记录数字之和s的位数
int count = 0;
int getCount(int n) {
//获得一个数字的位数
int i = 0;
while (n > 0) {
n /= 10;
i++;
}
return i;
}
void trans(int a) {
//将单个数字转换为拼音
static int i = 0;
switch (a) {
case 0:
cout << "ling";
break;
case 1:
cout << "yi";
break;
case 2:
cout << "er";
break;
case 3:
cout << "san";
break;
case 4:
cout << "si";
break;
case 5:
cout << "wu";
break;
case 6:
cout << "liu";
break;
case 7:
cout << "qi";
break;
case 8:
cout << "ba";
break;
case 9:
cout << "jiu";
break;
}
i++;
if (i < count) {
cout << " ";
}
}
void show(int n) {
//打印数字各个位的拼音
if (n / 10 == 0)
trans(n);
else {
show(n / 10);
trans(n % 10);
}
}
int main() {
string n;
int s = 0;
cin >> n;
for (int i = 0; i < n.length(); i++) {
s += n[i];
}
//48为0的ASCII码
s = s - n.length() * 48;
count = getCount(s);
show(s);
return 0;
}
|