寒假作业2 7-1 币值转换

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>
#include<math.h>
int aa(int a);
int bb(int b);
int main()
{
	int a/*输入数据*/,b/*总位数*/,c=1/*媒介*/,d[10]={1,1,1,1,1,1,1,1,1,1}/*各个位上的数字*/,e/*媒介*/,f/*总位数*/;
	scanf("%d",&a);
		/*总位数*/
	for(b=0;a/c>=10;b++)
		{
	        c=pow(10,b);
	    } 
	    f=b;
	    /*各个位上的数字*/
	for(b;b>0;b--)
	{
		d[b]=a/pow(10,b-1);
		e=pow(10,b-1);
		c=a%e;
		a=c;
	}
	/*输出*/ 
	if(f==0)	printf("a");
	else if(f%100000000==0)	{	
					bb(f/100000000);
				printf("Y");
			}
	else
		for(f;f>0;f--)
		{
			if(d[f]!=0)	
				if(d[f+1]==0)
				{
					printf("a");
					bb(d[f]);
					aa(f);
				}			
				else
				{	
					bb(d[f]);
					aa(f);
				}
			else if(f==5)	printf("W");
		}		
}

int aa(int a)
{
	switch(a)
		{
			case 1: printf("");break;
			case 2: printf("S");break;
			case 3: printf("B");break;
			case 4: printf("Q");break;
			case 5: printf("W");break;
			case 6: printf("S");break;
			case 7: printf("B");break;
			case 8: printf("Q");break;
			case 9: printf("Y");break;
	 }
}

int bb(int b)
{
	switch(b)
					{
				        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;
				    }
}

2)设计思路

1、直接将数据每一位单独提出,判断此数所在数位

		e=pow(10,b-1);
		c=a%e;
		a=c;

2、读出并判断是否需要读出零(非零数前有零读一个零,若d[f]!=0且d[f+1]==0则printf("a") 再输出数据
3、当存在万位及以上且要输出万位时只要输出一个万 if(f==5) printf("W");

注意

本题可以使用计算的方法进行运算但需要找到适当的函数,
而找到适当函数难度较大却可以判断超过亿位的数据(只需要较小幅度更改)
采用类似我的方法进行编程并不需要复杂的函数,简单粗暴的拆分判断但需要更改数据时更改很麻烦

3)本题调试过程碰到问题及解决办法

问题:未找到合适的函数
解决:数学思维很重要

4)运行结果截图

原文地址:https://www.cnblogs.com/5236288kai/p/10274315.html