读入一个自然数n,计算其各位数字之和,用汉语拼音写出和的每一位数字。
输入格式:每个测试输入包含1个测试用例,即给出自然数n的值。这里保证n小于10100。
输出格式:在一行内输出n的各位数字之和的每一位,拼音数字间有1 空格,但一行中最后一个拼音数字后没有空格。
输入样例:
1234567890987654321123456789
输出样例:
yi san wu 既然数字的长度是100位,所以很自然地用string类来存储。计算出和之后,只要递归输出数字对应的拼音就好了。推荐拼音用数组存储,省钱多个if冗杂的代码。需要注意递归时空格的问题
#include <bits/stdc++.h> using namespace std; char digit[10][10] = {"ling", "yi", "er", "san", "si", "wu", "liu", "qi", "ba", "jiu"}; void solve(int x); bool flag = true; int main() { string str; cin >> str; int cnt = 0; int len = str.length(); for(int i = 0; i < len; ++i){ cnt += str[i]-‘0‘; } solve(cnt); return 0; } void solve(int x){ if(x == 0){ return; } solve(x / 10); if(flag){ flag = false; } else{ printf(" "); } printf("%s", digit[x%10]); }
CAPOUIS‘S CODE
时间: 2024-10-14 17:08:30