7-23 币值转换
分数 20
输入一个整数(位数不超过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>//字符串库函数,因为后面要使用strcmp函数
char s[] = { '0', 'S', 'B', 'Q', 'W', 'S', 'B', 'Q', 'Y'};//笔者原来使用switch方法来选择,
//编译可以通过,但不如这种数组简
//便
int main()
{
char num[10]; //定义一个长度10的数组,但注意这里是char而不是int,因为我们要把这大串数字用
//字符表示,在后面进行字符串长度比较等操作
scanf("%s", num); //输入,注意%s,不用&
int len = strlen(num); //定义一个变量len,被赋值为数组的长度
strlen:计算字符串长度的函数
int i = 0, flag = 0; //设置一个常见的flag 0/1 标志
if (strcmp(num, "0") == 0 ) //strcmp(字符串1,字符串2)字符串比较函数
// 说明:
// 当s1<s2时,返回为负数 注意不是-1
// 当s1==s2时,返回值= 0
// 当s1>s2时,返回正数 注意不是1
{
printf("a"); //讨论特殊情况,如果是数字0,直接输出字母a
}
else //不是只有单个0,常规情况
{
while (i < len) //目的是遍历整个数组,把每个数字字符拎出来处理
{
if (num[i] != '0') //如果这个拎出来的不是0,常规操作
{
printf("%c", num[i] + 49); //输出这个数字字符阿斯卡码后49位的对应的小写字母
if (s[len - i - 1] != '0') //上个拎完了,-1,拎下一个,代表位数(十百千等
printf("%c", s[len - i - 1]); //输出第二位代表位数的大写字符(十百千等
flag = 0; //标志置0,标记着当前检测到的(拎出来的)数字不是0
i++; //i++,轮回继续
}
else //遇到0, 或者连续的0,flag置1
{
flag = 1;
i++;
}
if (num[i] != '0'&& num[i] != '\0' && flag && i != len - 4)
{
printf("a"); //遇到零后,第一次遇到非零0, 且不为万位,输出0
}
else if (flag && i == len - 4) //遇到零后,第一次遇到非零0, 且为万位,输出W
printf("W"); //指十万百万千万亿这些不能单用一个大写字母表示的,还得看看是不
//是得多个“万”字
}
}
printf("\n");
return 0;
}
这个题,我觉得挺难,写了好久。但写完呢,回头一瞅,好像也没那么难。注意就是得细心,小点还是蛮多的,比如我在这个十万,百万,千万那就编译怎么都不过。希望这篇对您有帮助哈哈哈~,一起努力,每天进步一点点!!