循环-19. 币值转换(20)
2015-04-23 20:50
211 查看
400 ms
内存限制
65536 kB
代码长度限制
8000 B
判题程序
Standard
作者
陈建海(浙江大学)
输入一个整数(位数不超过9位)代表一个人民币值(单位为元),请转换成财务要求的大写中文格式。如23108元,转换后变成“贰万叁仟壹百零捌”元。为了简化输出,用小写英文字母a-j顺序代表大写数字0-9,用S、B、Q、W、Y分别代表拾、百、仟、万、亿。于是23108元应被转换输出为“cWdQbBai”元。
输入格式:
输入在一行中给出一个不超过9位的非负整数。
输出格式:
在一行中输出转换后的结果。注意“零”的用法必须符合中文习惯。
输入样例1:
813227345
输出样例1:
iYbQdBcScWhQdBeSf
输入样例2:
6900
输出样例2:
gQjB
考虑了,考虑了最大的数,还有什么特殊情况么?为什么还是有错
#include <stdio.h> #include <string.h> int main() { char a[10]; char b[9][2]={"","S","B","Q","W","S","B","Q","Y"}; char c[10]={'a','b','c','d','e','f','g','h','i','j'}; gets(a); int m,i,j,n; m=strlen(a); if(a[0]=='0') printf("a\n"); else { for(i=0;i<m;i++) { n=0; if(a[i]=='0') { while(a[i]=='0') i++; if(i<m) printf("%c",c[0]); } if(a[i]=='1') printf("%c%s",c[1],b[m-1-i]); if(a[i]=='2') printf("%c%s",c[2],b[m-1-i]); if(a[i]=='3') printf("%c%s",c[3],b[m-1-i]); if(a[i]=='4') printf("%c%s",c[4],b[m-1-i]); if(a[i]=='5') printf("%c%s",c[5],b[m-1-i]); if(a[i]=='6') printf("%c%s",c[6],b[m-1-i]); if(a[i]=='7') printf("%c%s",c[7],b[m-1-i]); if(a[i]=='8') printf("%c%s",c[8],b[m-1-i]); if(a[i]=='9') printf("%c%s",c[9],b[m-1-i]); } printf("\n"); } return 0; }最后想到还要考虑万位上如果没有数时,如:100001;输出应该是bSWab,100000001输出应该是bYab
#include <stdio.h> #include <string.h> int main() { char a[10]; char b[9][2]={"","S","B","Q","W","S","B","Q","Y"}; char c[10]={'a','b','c','d','e','f','g','h','i','j'}; gets(a); int m,i,j,n; m=strlen(a); if(a[0]=='0') printf("a\n"); else { for(i=0;i<m;i++) { if(a[i]=='0') { while(a[i]=='0') { if((m-1-i==4)&&(a[i]=='0')) { n=0; for(j=0;j<i;j++) { if(a[j]=='0') n++; } if(n<3) printf("W"); } i++; } if(i<m) printf("%c",c[0]); } if(a[i]=='1') printf("%c%s",c[1],b[m-1-i]); if(a[i]=='2') printf("%c%s",c[2],b[m-1-i]); if(a[i]=='3') printf("%c%s",c[3],b[m-1-i]); if(a[i]=='4') printf("%c%s",c[4],b[m-1-i]); if(a[i]=='5') printf("%c%s",c[5],b[m-1-i]); if(a[i]=='6') printf("%c%s",c[6],b[m-1-i]); if(a[i]=='7') printf("%c%s",c[7],b[m-1-i]); if(a[i]=='8') printf("%c%s",c[8],b[m-1-i]); if(a[i]=='9') printf("%c%s",c[9],b[m-1-i]); } printf("\n"); } return 0; }
相关文章推荐
- 循环-19. 币值转换(20)
- 循环-19. 币值转换(20)
- PAT_B_循环-19. 币值转换(20)
- 循环-19. 币值转换(20)
- 循环-19. 币值转换(20)
- PAT : 循环-19. 币值转换(20)
- 循环-19. 币值转换
- [PTA] 7-23 币值转换(20 分)
- 19-集合框架工具类-20-常用对象API(集合框架-JDK5.0特性-ForEach循环)
- 7-23 币值转换(20 分)
- 5-23 币值转换
- 1008. 数组元素循环右移问题 (20)
- POJ 1930 Dead Fraction(循环小数转换成分数)
- 【PAT】(乙级)1008. 数组元素循环右移问题(20)
- 1008. 数组元素循环右移问题 (20)
- 循环-11. 水仙花数(20)<偷懒版>
- 循环-11. 水仙花数(20)
- 1008. 数组元素循环右移问题 (20)
- 简化以下程序,将函数对象 divide_by 转换为一个函数,并将 for 循环替换为用一个标准的 C++ 算法来输出数据
- 问题 1678: 算法2-18~2-19:双向循环链表