题目链接:http://pat.zju.edu.cn/contests/pat-b-practise/1002
读入一个自然数n,计算其各位数字之和,用汉语拼音写出和的每一位数字。
输入格式:每个测试输入包含1个测试用例,即给出自然数n的值。这里保证n小于10100。
输出格式:在一行内输出n的各位数字之和的每一位,拼音数字间有1 空格,但一行中最后一个拼音数字后没有空格。
输入样例:1234567890987654321123456789
输出样例:
yi san wu
代码如下:
#include <cstdio> #include <cstring> typedef long long LL; const int MAXN = 117; char s[MAXN]; char num[10][7] = {"ling","yi","er","san","si","wu","liu","qi","ba","jiu"}; int ans[MAXN]; LL sum; void Print() { int l = 0; while(sum > 0) { int tt = sum%10; ans[l++] = tt; sum/=10; // printf("%c\n",ans[l-1]); } for(int i = l-1; i > 0; i--) { printf("%s ",num[ans[i]]); } printf("%s\n",num[ans[0]]); } int main() { while(gets(s)) { int len = strlen(s); sum = 0; for(int i = 0; i < len; i++) { sum+=s[i]-'0'; } // printf("%I64d\n",sum); Print(); } return 0; }
原文地址:http://blog.csdn.net/u012860063/article/details/39348017