5-2. 念数字(15)
时间限制
400 ms
内存限制
32000 kB
代码长度限制
8000 B
判题程序
Standard
作者
翁恺(浙江大学)
输入一个整数,输出每个数字对应的拼音。当整数为负数时,先输出“fu”字。十个数字对应的拼音如下:
0: ling 1: yi 2: er 3: san 4: si 5: wu 6: liu 7: qi 8: ba 9: jiu
输入格式:
输入在一行中给出一个整数,如: 1234
。
提示:整数包括负数、零和正数。
输出格式:
在一行中输出这个整数对应的拼音,每个数字的拼音之间用空格分开,行末没有最后的空格。如 yi er san si
。
-600输出样例:
fu liu ling ling
#include <stdio.h> int main() { int x; int cnt,mask; cnt=0; mask=1; int d; int t; //printf("%d\n",12345%1000000); scanf("%d",&x); if(x<0){//判断是否为负数,并将负数转换为正数 x=-x; printf("fu "); } t=x;//保持传入的x值不被消耗掉 while(t>9) { t/=10;//依次去掉右边一位,循环次数加一就是有几位数 //所以cut初始值设为1 cnt++;//其实没有用到计数,利用循环输出了每一个数字 mask*=10;//同时计算出mask值,就是每次模数,除数 //printf("x=%d,cnt=%d,mask=%d\n",t,cnt,mask); } while(mask>0) { d=x/mask;//ex:12345/10000=1,12345%10000=2345,10000/10=1000 //printf("%d",d); switch(d)//得到的每一位用switch case判断输出 { case 0: printf("ling"); break; case 1: printf("yi"); break; case 2: printf("er"); break; case 3: printf("san"); break; case 4: printf("si"); break; case 5: printf("wu"); break; case 6: printf("liu"); break; case 7: printf("qi"); break; case 8: printf("ba"); break; case 9: printf("jiu"); break; default: printf(" "); } if(mask>9)//去除末尾最后的空格 //只有不是最后一位的时候才输出空格 { printf(" "); } x%=mask; mask/=10; } return 0; }