#include <stdio.h>
int main()
{
char A[10]={'a','b','c','d','e','f','g','h','i','j'};//建立数字对应的字母数组
int B[10]={0}; //初始化数组,用于储存输入的每一位数字
int number,i=0;
scanf("%d",&number);
if(number==0) printf("a"); //如果输入的数字为0,输出a
while(number!=0) //将输入的数字提取至数组B中
{
B[i]=number%10;
i++;
number/=10;
}
i--;
if(i==8) //最关键的部分,中文币值的输出规则中“零”的使用情况
{ //当上一位为零且后面几位均不为零时,才输出零;以4位为一个循环
printf("%cY",A[B[i]]);//9位数的情况,输出“亿”
if(B[7]!=0) printf("%cQ",A[B[7]]);
else if(B[6]!=0||B[5]!=0||B[4]!=0) printf("a");//B[7]==0
if(B[6]!=0) printf("%cB",A[B[6]]);
else if(B[7]!=0&&(B[5]!=0||B[4]!=0)) printf("a");//B[6]==0
if(B[5]!=0) printf("%cS",A[B[5]]);
else if(B[6]!=0&&(B[4]!=0)) printf("a");//B[5]==10
if(B[4]!=0) printf("%c",A[B[4]]);
if(B[7]!=0||B[6]!=0||B[5]!=0||B[4]!=0) printf("W"); //是否输出“万”
if(B[3]!=0) printf("%cQ",A[B[3]]);
else if(B[2]!=0||B[1]!=0||B[0]!=0) printf("a");//B[3]==0
if(B[2]!=0) printf("%cB",A[B[2]]);
else if(B[3]!=0&&(B[1]!=0||B[0]!=0)) printf("a");//B[2]==0
if(B[1]!=0) printf("%cS",A[B[1]]);
else if(B[2]!=0&&B[0]!=0) printf("a");//B[1]==0
if(B[0]!=0) printf("%c",A[B[0]]);
}
else if(i>=4&&i<=7) //5~8位数的情况,需要输出“万”
{
if(B[7]!=0) printf("%cQ",A[B[7]]);
if(B[6]!=0) printf("%cB",A[B[6]]);
else if(B[7]!=0&&(B[5]!=0||B[4]!=0)) printf("a");//B[6]==0
if(B[5]!=0) printf("%cS",A[B[5]]);
else if(B[6]!=0&&(B[4]!=0)) printf("a");//B[5]==10
if(B[4]!=0) printf("%c",A[B[4]]);
if(B[7]!=0||B[6]!=0||B[5]!=0||B[4]!=0) printf("W");
if(B[3]!=0) printf("%cQ",A[B[3]]);
else if(B[2]!=0||B[1]!=0||B[0]!=0) printf("a");//B[3]==0
if(B[2]!=0) printf("%cB",A[B[2]]);
else if(B[3]!=0&&(B[1]!=0||B[0]!=0)) printf("a");//B[2]==0
if(B[1]!=0) printf("%cS",A[B[1]]);
else if(B[2]!=0&&B[0]!=0) printf("a");//B[1]==0
if(B[0]!=0) printf("%c",A[B[0]]);
}
else if(i>=0&&i<=3) //1~4位数的情况,注意一个特殊情况“0”
{
if(B[3]!=0) printf("%cQ",A[B[3]]);
if(B[2]!=0) printf("%cB",A[B[2]]);
else if(B[3]!=0&&(B[1]!=0||B[0]!=0)) printf("a");//B[2]==0
if(B[1]!=0) printf("%cS",A[B[1]]);
else if(B[2]!=0&&B[0]!=0) printf("a");//B[1]==0
if(B[0]!=0) printf("%c",A[B[0]]);
}
return 0;
}
以上是我个人觉得比较简洁易懂的C语言解决币值转化的方法,如果拓展到更多位数,也比较容易做出相应的调整。
欢迎博友提供新思路和建议。