7-1 币值转换 (20 分)
输入一个整数(位数不超过9位)代表一个人民币值(单位为元),请转换成财务要求的大写中文格式。如23108元,转换后变成“贰万叁仟壹百零捌”元。为了简化输出,用小写英文字母a-j顺序代表大写数字0-9,用S、B、Q、W、Y分别代表拾、百、仟、万、亿。于是23108元应被转换输出为“cWdQbBai”元。
输入格式:
输入在一行中给出一个不超过9位的非负整数。
输出格式:
在一行中输出转换后的结果。注意“零”的用法必须符合中文习惯。
输入样例1:
813227345
输出样例1:
iYbQdBcScWhQdBeSf
输入样例2:
6900
输出样例2:
gQjB
1).实验代码
#include<stdio.h> int main (void) { int n, v, v1, v2, s=0, j, v3, q=1000, k=0, N=0; scanf("%d", &n); v=n/100000000; if(value!=0) { printf("%cY",'a'+v); } v1=n%100000000; v2=value1/10000; while(q!=0) { if(v2==0) { break; } j=v2/q; v2=v2%q; q=q/10; k++; if(v==0&&j==0) { if(N!=1) { continue; } } if(j==0) { s++; if(s<=1) { if(y!=4) { printf("%c", 'a'); } } } if(x!=0 ){ s=0; N=1; printf("%c", 'a'+j); switch(k){ case 1: printf("Q"); break; case 2: printf("B"); break; case 3: printf("S"); break; } } } if(k!=0) { printf("W"); } s=0; q=1000; y=0; N=0; v3=n%10000; while(q!=0){ j=v3/q; v3=v3%q; q=q/10; k++; if((n%100000000)/10000==0&&x==0){ if(N!=1){ continue; } } if(v3!=0) { if(x==0) { sum++; if(sum<=1) { printf("%c", 'a'); } } } if(j!=0){ s=0; N=1; printf("%c", 'a'+j); switch(k){ case 1: printf("Q"); break; case 2: printf("B"); break; case 3: printf("S"); break; } } } if(n==0) { printf("%c", 'a'); } }
2) 设计思路
![](https://img2018.cnblogs.com/blog/1582246/201902/1582246-20190217202936767-1561643945.png)
调试过程遇到的问题及解决方法
首先这道题在思路上就遇到了一些问题,我当时的想法是将每一部分都分开用while判断是否为0,但是后面做出来后遇到了许多麻烦(在多个0只显示一个的问题上犯愁),在咨询了数位大佬后选择了这种将万位一下一次性处理,我也试过所有的数一起编写,但是我最后还是失败了,一直显示错误,我估摸着还是因为在出现多个0时我的处理出现了问题。但是我觉得一起编写应该是最简单的一种方法了,而且应该是可行的。
运行结果截图