读入一个自然数n,计算其各位数字之和,用汉语拼音写出和的每一位数字。
输入格式:每个测试输入包含1个测试用例,即给出自然数n的值。这里保证n小于10100。
输出格式:在一行内输出n的各位数字之和的每一位,拼音数字间有1 空格,但一行中最后一个拼音数字后没有空格。
输入样例:1234567890987654321123456789输出样例:
yi san wu
题目主要考查,超出int类型的数据的处理,很明显,int类型的数据不能达到10^100.所以我们要用char定义,每一个数字占一个内存。
#include <iostream> #include <string.h> using namespace std; int main() { char a[10000]; int b[10000]; int c[100]; int sum = 0,d=0; cin>>a; int k = strlen(a); for (int i=0;i<k;i++){ b[i]=a[i]-'0'; } for (int i=0;i<k;i++){ sum += b[i]; } while (sum!=0){ c[d] = sum%10; sum/=10; d++; } for (int i=d-1;i>0;i--){ switch(c[i]){ case 0:cout<<"ling ";break; case 1:cout<<"yi ";break; case 2:cout<<"er ";break; case 3:cout<<"san ";break; case 4:cout<<"si ";break; case 5:cout<<"wu ";break; case 6:cout<<"liu ";break; case 7:cout<<"qi ";break; case 8:cout<<"ba ";break; case 9:cout<<"jiu ";break; } } switch(c[0]){ case 0:cout<<"ling";break; case 1:cout<<"yi";break; case 2:cout<<"er";break; case 3:cout<<"san";break; case 4:cout<<"si";break; case 5:cout<<"wu";break; case 6:cout<<"liu";break; case 7:cout<<"qi";break; case 8:cout<<"ba";break; case 9:cout<<"jiu";break; } return 0; }