7-1 幣值轉換 (20 分)


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

實驗代碼

#include<stdio.h>  
int main (void)
{
	int n, value, value1, value2, sum=0, x, value3, qian=1000, y=0, jishuqi=0;
	scanf("%d", &n);
	value=n/100000000;
	if(value!=0){
		printf("%cY", 'a'+value);                      /*輸出億位*/
	}
        value1=n%100000000;
	value2=value1/10000;                                 /*得到萬位數字*/
	while(qian!=0){                                            /*輸出萬位*/
		if(value2==0){
			break;
		}
		x=value2/qian;
		value2=value2%qian;
		qian=qian/10;
		y++;
		if(value==0&&x==0){                
			if(jishuqi!=1){
				continue;
			}
		}
		if(x==0){
			sum++;
			if(sum<=1) {
				if(y!=4){
					printf("%c", 'a');
				}	
			}
		}
		if(x!=0){
			sum=0;
			jishuqi=1;
			printf("%c", 'a'+x);
			switch(y){
				case 1: printf("Q"); break;
				case 2: printf("B"); break;
				case 3: printf("S"); break;
			}
		}
	}
	if(y!=0){
		printf("W");                                      /*輸出萬位結束*/
	}
	sum=0;                                                    /*輸出千位以下需要重新賦初始值,因為在萬位運算的時候值變化了*/
	qian=1000;
	y=0;
	jishuqi=0;
	value3=n%10000;                                    /*得到千以及以下數字*/
	while(qian!=0){
		x=value3/qian;
		value3=value3%qian;
		qian=qian/10;
		y++;
		if((n%100000000)/10000==0&&x==0){
			if(jishuqi!=1){
				continue;
			}
		}
		if(value3!=0){
			if(x==0){
			    sum++;
			    if(sum<=1) {
				    printf("%c", 'a');
			    }
		    }
		}
		if(x!=0){
			sum=0;
			jishuqi=1;
			printf("%c", 'a'+x);
			switch(y){
				case 1: printf("Q"); break;
				case 2: printf("B"); break;
				case 3: printf("S"); break;
			}
		}
	}
        if(n==0){
		printf("%c", 'a');
	}	
} 

設計思路

第一步:整體來看,把他們區分為三個區間,分別是億,萬,千以下
第二步:輸出億位,這個很簡單
第三部:輸出萬位,這個考慮的就有很多,比如首位是零,還有連續的零,最后一個是零,下面一一講解
********:第一:比如億位為零且萬位第一位位為零,那么這個零不能輸出

if(value==0&&x==0){
			if(jishuqi!=1){
				continue;
			}
		}

********:第二:萬位中間有兩個零,但按我們中文規則只能輸出一個零,且沒有“零百”,“零十”,而且最后一位為零不輸出

               if(x==0){
			sum++;
			if(sum<=1) {
				if(y!=4){
					printf("%c", 'a');
				}	
			}
		}

********:有數字的輸出千,百,十位

if(x!=0){
			sum=0;
			jishuqi=1;
			printf("%c", 'a'+x);
			switch(y){
				case 1: printf("Q"); break;
				case 2: printf("B"); break;
				case 3: printf("S"); break;
			}
		}
	}

********:下面這個用來判斷是否有萬位上的數字

if(y!=0){
		printf("W");
	}

第四步:輸出千以下位,大概同萬位運算方法一樣

總結:這個萬位的輸出和千以下位的輸出差不多,但是萬位的細小條件更多,我原本還想自定義一個函數運算這兩部分的,思考了,但是沒深入思考,感覺應該是可行的。

調試過程遇到的問題及解決方法

這個題沒調試過,直接輸入,看輸出結果,從結果判斷問題所在。
因為這個題是分開編譯出來的,初始條件相同,並按要求輸出,我是一個一個問題解決的:先解決第一個零不輸出的問題,再解決中間零的輸出問題,最后解決最后一位是零的不輸出問題。
在這個題中,計數器我感覺很重要,我設計的這個程序很多地方的輸出要靠計數器,我感覺這個題還不夠簡便,但是現在看的話感覺思路還是挺清晰的。

運行結果截圖


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM