读入一个正整数 n,计算其各位数字之和,用汉语拼音写出和的每一位数字。
每个测试输入包含 1 个测试用例,即给出自然数 n 的值。这里保证 n 小于 1。
在一行内输出 n 的各位数字之和的每一位,拼音数字间有 1 空格,但一行中最后一个拼音数字后没有空格。
1234567890987654321123456789
yi san wu
思路:使用stringstream流工具,进行string和int的转换,最后按位输出即可。
#include <iostream> #include <cstring> #include <algorithm> #include <string.h> #include <sstream> using namespace std; int main() { string s,t; cin>>s; int n,f; for(int i=0;i<s.length();i++) { stringstream ss; ss<<s[i]; ss>>n; f+=n; } stringstream tt; tt<<f; tt>>t; for(int i=0;i<t.length();i++) { if(i!=0)printf(" "); if(t[i]==‘1‘)printf("yi"); if(t[i]==‘2‘)printf("er"); if(t[i]==‘3‘)printf("san"); if(t[i]==‘4‘)printf("si"); if(t[i]==‘5‘)printf("wu"); if(t[i]==‘6‘)printf("liu"); if(t[i]==‘7‘)printf("qi"); if(t[i]==‘8‘)printf("ba"); if(t[i]==‘9‘)printf("jiu"); if(t[i]==‘0‘)printf("ling"); } return 0; }
原文:https://www.cnblogs.com/whocarethat/p/11135228.html