PTA基础编程题目集~7-23币值转换(全注释系列)

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;
}

这个题,我觉得挺难,写了好久。但写完呢,回头一瞅,好像也没那么难。注意就是得细心,小点还是蛮多的,比如我在这个十万,百万,千万那就编译怎么都不过。希望这篇对您有帮助哈哈哈~,一起努力,每天进步一点点!!

  • 3
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值