读入一个正整数 n,计算其各位数字之和,用汉语拼音写出和的每一位数字。
输入格式:
每个测试输入包含 1 个测试用例,即给出自然数 n 的值。这里保证 n 小于 10100 。
输出格式:
在一行内输出 n 的各位数字之和的每一位,拼音数字间有 1 空格,但一行中最后一个拼音数字后没有空格。
输入样例:
1234567890987654321123456789
输出样例:
yi san wu
思路:
① 用字符数组接收输入的数,求出各位数字的和
② 输入的数不大于 10100,则各位数字的和不大于 10 × 100
③ 用一个 int 型数组储存和的各位数字并以拼音形式输出
#include<iostream>
using namespace std;
int main()
{
int i, sum = 0, strl = 0, ar[5];
char arr[103];
cin >> arr;
strl = strlen(arr);
for (i = 1; i <= strl; i++)
{
sum += (arr[i - 1] - '0');
}
i = -1;
do
{
i++;
ar[i] = sum % 10;
sum = sum / 10;
} while (sum > 0);
for (i; i != -1; i--)
{
switch (ar[i])
{
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;
case 0:
cout << "ling"; break;
}
if (i != 0)cout << " ";
}
return 0;
}

被折叠的 条评论
为什么被折叠?



