题滴链接https://pintia.cn/problem-sets/994805260223102976/problems/994805324509200384
1002 写出这个数 (20 分)
读入一个正整数 n,计算其各位数字之和,用汉语拼音写出和的每一位数字。
输入格式:
每个测试输入包含 1 个测试用例,即给出自然数 n 的值。这里保证 n 小于 10100。
输出格式:
在一行内输出 n 的各位数字之和的每一位,拼音数字间有 1 空格,但一行中最后一个拼音数字后没有空格。
输入样例:
1234567890987654321123456789
输出样例:
yi san wu
鄙人拙见:
- 长长长整数用字符串解决
- 求和
- 取出各位的数字
- 再求和
- 最后转换为拼音
C++参考代码1.0:
#include <bits/stdc++.h>
using namespace std;
int main()
{
char num[101];
scanf("%s",num);
int sum = 0;
for(int i = 0; num[i] != 0; i++)
{
sum = sum + num[i] - '0';
}
int gewei[100];
int t = 0;
while(sum > 0)
{
gewei[t] = sum % 10;
sum = sum / 10;
t = t + 1;
}
for(int i = t - 1; i >= 0; i--)
{
if(gewei[i] == 0)
{
printf("ling");
}
if(gewei[i] == 1)
{
printf("yi");
}
if(gewei[i] == 2)
{
printf("er");
}
if(gewei[i] == 3)
{
printf("san");
}
if(gewei[i] == 4)
{
printf("si");
}
if(gewei[i] == 5)
{
printf("wu");
}
if(gewei[i] == 6)
{
printf("liu");
}
if(gewei[i] == 7)
{
printf("qi");
}
if(gewei[i] == 8)
{
printf("ba");
}
if(gewei[i] == 9)
{
printf("jiu");
}
if(i > 0)
{
printf(" ");
}
}
return 0;
}