读入一个自然数n,计算其各位数字之和,用汉语拼音写出和的每一位数字。
输入格式:每个测试输入包含1个测试用例,即给出自然数n的值。这里保证n小于10100。
输出格式:在一行内输出n的各位数字之和的每一位,拼音数字间有1 空格,但一行中最后一个拼音数字后没有空格。
输入样例:1234567890987654321123456789输出样例:
yi san wu
分析:
1.读入一个数,计算其各位数字之和,注意这个数可能大于int型数据的范围,所以最好用string.
2.依次取出和的各个位数的数字,这里n小于10的100次方,所以sum<=900.
3.用switch语句,将数字与中文拼音对应起来.或者用string数组,将中文拼音先存起来.
源代码:
#include<iostream> using namespace std; void print(int s) { switch(s) { 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; } } int main() { string s1;int nu[4]; int length=0; cin>>s1;int sum=0; for(int i=0;i<s1.length();i++)//计算sum { sum+=s1[i]-'0'; } int k=0; while(sum!=0) { nu[k]=sum%10; sum=sum/10; length++; k++; }//得到反向数组 while(length!=0) { if(length==1) { print(nu[0]); cout<<endl; } else{ print(nu[length-1]); cout<<" "; } length--; } return 0; }