这道题跟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)