ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

币值转换

2019-03-01 13:40:44  阅读:263  来源: 互联网

标签:转换 cur bitnum ++ 单位 币值 输入 数字


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
首先从宏观上来看,我们需要一个存放数字即a-f的字符数组,一个存放单位即S,B,Q,W,Y的字符数组,还需要一个结果数组,存放单位和数字的组合。在题目保证输入为非负整数的情况下,首先需判定输入数为0的情况,一般的处理手段是输出a,return 0。如果输入数不为0,那么将输入数从低到高取位判定。取得的当前位有0和非0之分,若当前位非0,且当前位数不为1即当前位不为个位,则存放单位与数字。注意由于一开始不知道输入数的位数,故结果数组的索引只能从低到高,一般从0开始,所以先存放单位,后存放数字。若当前位为0,则大概需要注意下述3种情况:
1.有单位,无数字:万位
2.无单位,无数字:
2.1 千位,个位
2.2 除万位之外,前面一位为0
3.无单位,有数字:
include
using namespace std;
int main()
{
char NUM[10]={'a','b','c','d','e','f','g','h','i','j'};

//存数字

char UNIT[10]={0,0,'S','B','Q','W','S','B','Q','Y'};

//存单位,为将下标与位数对应,前两个单元存0

char RESULT[17];//存结果,最多存9个数字,8个单位

int n,k=0,bitnum=0,cur,pre;

//定义输入数字,结果数组索引,位数,当前位,前一位

cin>>n;

if(!n)

{

cout<<NUM[0];//注意若输入数为0,输出a 

return 0;

}

while(n)//否则从低位到高位取位判定

{

cur=n%10;

n/=10;//注意n及时除10 

bitnum++;

if(cur)//如果当前位不为0 

{

    if(bitnum>1) //如果不为个位,存单位 

    RESULT[k++]=UNIT[bitnum];   

    RESULT[k++]=NUM[cur];//无论如何,存数字 

}

else//如果当前位为0 

{

    if(bitnum==5)//若为万位 

    RESULT[k++]=UNIT[bitnum];//必存单位 

    else if(pre!=0&&bitnum!=4&&bitnum!=1)//若不为万位,千位,个位,且前一位不为0 

    RESULT[k++]=NUM[cur];//存当前的数字0

}

pre=cur;//注意及时保存当前位 

}

for(int i=k-1;i>=0;i--)//倒序输出结果

cout<<RESULT[i];

return 0;
}

设计思路
第一步:设计出思路理好程序框图
第二步:理解题目要求
第三步:打出代码

本题调试过程遇到的问题及解决方法
无,本次作业未写

标签:转换,cur,bitnum,++,单位,币值,输入,数字
来源: https://www.cnblogs.com/shsy/p/10455899.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有