币值转换

include<stdio.h>

include<math.h>

int n,s=0;
int main(void)
{
int i,j,k,p=1,flag=1;
int f(int q,int n);
scanf("%d",&n);

for(i=0;n/p>=10;i++){
p=pow(10,i);
s++;
}
if(n0)
printf("a");
if(n<10&&n>=0)
s=1;
for(j=1;j<=s;j++){
switch(f(j,n)){
case 0:if(j!=s&&j!=s-4){
if(f(j+1,n)
0)
flag=0;
else
flag=1;
if(flag)printf("a");break;
};break;
case 1:printf("b");break;
case 2:printf("c");break;
case 3:printf("d");break;
case 4:printf("e");break;
case 5:printf("f");break;
case 6:printf("g");break;
case 7:printf("h");break;
case 8:printf("i");break;
case 9:printf("j");break;
}
if(f(j,n)0&&j!=s&&j!=s-4)
continue;
else{
if(s
9&&j5){
if(f(2,n)
0&&f(3,n)0&&f(4,n)0&&f(5,n)0)
continue;
}
switch(s-j){
case 1:printf("S");break;
case 2:printf("B");break;
case 3:printf("Q");break;
case 4:printf("W");break;
case 5:printf("S");break;
case 6:printf("B");break;
case 7:printf("Q");break;
case 8:printf("Y");break;
}
}}
return 0;
}
int f(int q,int n)
{
int k,a;
if(q
1)
k=n/pow(10,s-1);
else{
a=n/pow(10,s-q+1);
k=n/pow(10,s-q)-a*10;
}
return k;
}
三、实验思路
根据题目意思 小写英文字母a-j顺序代表大写数字0-9,用S、B、Q、W、Y分别代表拾、百、仟、万、亿
随机输入一个数n 从最高位开始作除依次给出对应的a-j字母对应数字后再接相应单位所对应的字符 后面的也如此 利用循环结构比较简便求解
四、调试过程碰到问题及解决办法
循环体结构出错 判断0的个数有问题不知如何表达并用代码解决
最后还是看同学的代码 不过还是看不懂...等到学校当面询问

原文地址:https://www.cnblogs.com/luoyuliang/p/10414763.html