这道题跟HJ42很像,都属于大模拟题目,但感觉这道题简单些,可能是母语的关系
题目有个问题,就是没标明数据范围,实际上在亿以上再给单位就变得模糊了,亿、万亿、亿亿,然后呢?万亿亿还是亿万亿呢,感觉往后就不太方便了,而题目中又没有对此说明。HJ42是说了数据范围的。
这里我的代码是只处理到千亿级数据(这是我在揣摩出题人的意图,我猜他只把单位给到了亿,又没有给数据范围,应该是只考察亿这一级的数据,害太难了,做个题还得猜出题人到底怎么想的)
总体思路:
按4位一组分开,每一组用函数f处理,处理完后再加上这一组对应的单位(元、万、亿)
函数f:
把输入字符倒序,再给每一个字符搭配上自己的单位(空、拾、佰、仟),这里最低位一定是空,因为输入字符可能是万级、亿级的,只有最低4位才应该搭配元(这个搭配在上面分组的时候已经做好了)。这里不用管字符是否为“0”,在后面通过正则表达式把“零仟”、“零百”这一类数据直接替换为“零”即可,对于连续的“零”,也使用正则表达式进行处理。
该说不说,正则表达式是真滴好用!
最后一点小吐槽
#对于0.31,这样的整数部分为0的数据会有问题,但是oj好像不管,我暂时不处理,另外这里有争议,到底是“零元叁角壹分”还是“叁角壹分”
#另外有一个类似问题,最后调到过19/20,就是这个数据——5.07,按照题目要求应该是【人民币伍元零柒分】,但是标准输出是【人民币伍元柒分】,感觉这题目出得不太严谨
import re std1="零、壹、贰、叁、肆、伍、陆、柒、捌、玖、拾、佰、仟、万、亿".split("、") std2=[i for i in "0、1、2、3、4、5、6、7、8、9、10".split("、")] std3=["","拾","佰","仟"] std4=["","万","亿"] a=input().split(".") zheng=a[0] zl=[] xiao=a[1] #处理小数部分 ans2="" if xiao=="00": ans2="整" else: ans2+=std1[std2.index(xiao[0])]+"角"+std1[std2.index(xiao[1])]+"分" ans2=re.sub("零角","",ans2) ans2=re.sub("零分","",ans2) #先定义f()处理10000以下的整数部分,10000以上的用f()处理 def f(a):#a为4位以内的整数 ans1="" if a=="0": return "零" else: a="0"*(4-len(a))+a for i in range(len(a[::-1])):#从低位到高位处理 ans1+=std3[i]+std1[std2.index(a[::-1][i])]#倒过来存储 ans1=ans1[::-1] return ans1 l=[]#4位一组存进l for i in range(0,len(zheng),4): l.append(zheng[::-1][i:i+4]) #把倒过来的数字恢复 for i in range(len(l)): l[i]=l[i][::-1] ans3=[] #对每组数字调用f for i in range(len(l)): ans3.append(f(l[i])+std4[i]) ans4="" #调用完成后调整位置,让高位排在前面 for i in ans3[::-1]: ans4+=i ans4=re.sub("零.{1}","零",ans4)#将“零千”、“零百”等替换为“零” ans4=re.sub("零{2,5}","零",ans4)#把多余的“零”,变成一个 ans4=re.sub("壹拾","拾",ans4)#壹拾改成拾 ans4=re.sub("(零).{1}仟","",ans4)#零几千改成几千 if ans4[0]=="零":#删除开头零 ans4=ans4[1:] ans5="人民币"+ans4+"元"+ans2 ans5=re.sub("零元","元",ans5) ans5=re.sub("人民币元","人民币",ans5) print(ans5)