题目
读入一个正整数 n,计算其各位数字之和,用汉语拼音写出和的每一位数字。
输入格式:
每个测试输入包含 1 个测试用例,即给出自然数 n 的值。这里保证 n 小于 1 0 100 10^{100} 10100
输出格式:
在一行内输出 n 的各位数字之和的每一位,拼音数字间有 1 空格,但一行中最后一个拼音数字后没有空格。
输入样例:
1234567890987654321123456789
输出样例:
yi san wu
思路分析:
用string接收输入,string的每一位数字累加到total里面,再将total转换为string类型的total,对total的每一位输出对应中文拼音
代码:
#include <iostream>
using namespace std;
string q[] = {"ling", "yi", "er", "san", "si", "wu", "liu", "qi", "ba", "jiu"}; //将0~9的拼音储存在字符串中
int main(){
string s; //用字符串储存数字,基本数据类型储存不下就可以考虑用字符串
cin >> s;
int total = 0;
for(int i = 0; i < s.size(); i++) total += s[i] - 48; //将其求和
string arr = to_string(total); //to_string()函数将基本数据类型转换为string类型
for(int i = 0; i < arr.size(); i++) printf("%s%s", i ? " " : "", q[arr[i] - 48].c_str()); //.c_str()函数将string类型转换为char类型输出,如果用cout可以直接输出string。
return 0;
}