当前位置: 代码迷 >> 综合 >> 1084:写出来吧
  详细解决方案

1084:写出来吧

热度:60   发布时间:2023-12-06 11:52:54.0

1084: 写出来吧

时间限制: 1 Sec   内存限制: 128 MB
提交: 0   解决: 0
[ 提交][ 状态][ 讨论版]

题目描述

读入一个自然数n,计算其各位数字之和,用汉语拼音写出和的每一位数字。

输入

每个测试输入包含1个测试用例,即给出自然数n的值。这里保证n小于10100

输出

在一行内输出n的各位数字之和的每一位,拼音数字间有1 空格,但一行中最后一个拼音数字后没有空格。

样例输入

1234567890987654321123456789

样例输出

yi san wu

提示

友情提示汉语拼音

0~9:ling yi er san si wu liu qi ba jiu shi

十:shi

百:bai

千:qian



【吐槽】n小于10的100次方也就是输入的数字最多99位,所以定义数组时可以将大小控制在100.如果每位都是9,和是891,最大就是三位数。最小的话一位数也是有可能的。如果要讨论一位数两位数三位数的情况比较麻烦,所以使用同样的方法,依次取最后一位存放在结果数组中。这里还被提示舞蹈了一下,居然又shi bai qian,我以为还要讨论整百整十的情况……再仔细看看题目,分别输出每一位就行了啦!

那么如何输出拼音呢?可以建一个数组,依次存放ling yi er……这样,就可以把每一位的数字当做下标啦。

#include <iostream>
using namespace std;
const int N = 1000;
int main(){char a[N];char pinyin[11][5] = { "ling", "yi", "er", "san", "si", "wu", "liu", "qi", "ba", "jiu" };memset(a, 0, sizeof(a));gets_s(a);int len = strlen(a);int i,sum=0;for (i = 0; i < len; i++)sum += a[i]-'0';int t = 0;int result[5];while (sum != 0){result[t] = sum % 10;sum = sum / 10;t++;}for (i = t - 1; i>0; i--){cout << pinyin[result[i]] << " ";}cout << pinyin[result[0]];system("pause");return 0;
}