就我不坑
时间限制:
1000 ms | 内存限制:
65535 KB
难度:
0
-
描述
-
as we all know ,就我不坑,呵呵,当然,这次我还是不坑,我只让你帮我翻译一下数字即可。
所谓翻译,就是将一个数字用中文读出来,很简单吧,快快AC吧。
数字的中文表示分别为:零、壹、贰、叁、肆、伍、陆、柒、捌、玖、拾、佰、仟、万、亿.
-
输入
- int 范围内,保证没错,EOF。 输出
- 用我给你的中文写出来就好了 样例输入
-
10 1052 10000
样例输出
-
壹拾 壹仟零伍拾贰 壹万
提示
-
我真的不坑。
#include<stdio.h> int Judge(int a,int b) { switch(a) { case 1:printf("壹");break; case 2:printf("贰");break; case 3:printf("叁");break; case 4:printf("肆");break; case 5:printf("伍");break; case 6:printf("陆");break; case 7:printf("柒");break; case 8:printf("捌");break; case 9:printf("玖"); } switch(b) { case 1:printf("拾");break; case 2:printf("佰");break; case 3:printf("仟");break; case 4:printf("万");break; case 5:printf("拾");break; case 6:printf("佰");break; case 7:printf("仟");break; case 8:printf("亿");break; case 9:printf("拾"); } } int main() { int i; unsigned n; int a[11]={0,1,10,100,1000,10000,100000,1000000,10000000,100000000,1000000000};//a[i]的值用来传递到ID函数中输出"位"的 while(scanf("%d",&n)!=EOF) { if(n==0) //针对n=0 时输出结果 { printf("零\n");continue; } int jd=0;//记录每个位上的数值 int c=n;//保留了原来的 n for(i=10;i>0;i--) { if(n/a[i]) { if(jd>5&&jd<9&&jd>=i+2&&i<5)//判断特殊数据输出"万"的情况:(1) jd>5&&jd<9&&jd>=i+2针对 1101111,11001111之类输出万 //(2) i<5防止当数据如10101111时输出"壹仟万零一拾万。。。"这种错误情况 Judge(0,4); if(jd>9&&jd>=i+2) Judge(0,8); if(jd-1>i&&i!=4&&i!=8)//输出数据如1010中"壹仟零壹拾"中的"零" printf("零"); Judge(n/a[i],0);jd=i; //输出数值 Judge(0,i-1); //输出位 } n=n%a[i]; //输出一位后向左移动一位继续循环输出 } if(c%100000==0&&c<100000000) //处理对于n00000~n0000000 输出"万" Judge(0,4); if(c%1000000000==0) //处理对于10亿的情况输出亿 Judge(0,8); printf("\n"); } return 0; }