解题思路:
每四位分开读,具体见代码和注释
参考代码:
d = {'1':'yi', '2':'er', '3':'san', '4':'si', '5':'wu', '6':'liu', '7':'qi', '8':'ba', '9':'jiu', '0':'ling'} n = input().strip() a = [] b = [] # 定义函数,读四位数的拼音 def exchange(n): # 先将数字逆序 # b用来存储读法的逆序 n = n[::-1] for i in range(len(n)): # 对于第一个(对应原数字最后一个) if i==0: # 不为0,则正常读 if n[i]!='0': b.append(d[n[i]]) # 对于第二个(对应原数字倒数第二个) elif i==1: # 为0,且前一个不为0 if n[i]=='0' and n[0]!='0': # 读 'ling' b.append(d['0']) # 为1,且只有两位,则读 十('shi') elif n[i]=='1' and len(n)==2: b.append('shi') # 不为0,读 几十('shi') elif n[i]!='0': b.append('shi') b.append(d[n[i]]) # 对于第三个数(对应原数字的第二个数) elif i==2: # 为0,且前一个不为0 if n[i]=='0' and n[1]!='0': # 读 零('ling') b.append(d['0']) # 不为0,读 几百('bai') elif n[i]!='0': b.append('bai') b.append(d[n[i]]) # 对于第四个数(对应原数字的第一个数) elif i==3: # 为0,且前一个不为0 if n[i]=='0' and n[2]!='0': # 读 零('ling') b.append(d['0']) # 不为0,读 几千('qian') elif n[i]!='0': b.append('qian') b.append(d[n[i]]) while n!='': # 不为空 # 四位及以上 # 最终得到一个列表a,是从个位开始,每四位截取为一个元素 if len(n)>=4: s = n[-4:] # 取出后四位 n = n[:-4] # 删除后四位 a.append(s) # 将后四位写入列表a else: a.append(n) n = '' for i in range(len(a)): if i==0: # 对于:个、十、百、千位 exchange(a[i]) elif i==1: # 对于:万、十万、百万、千万位 b.append('wan') exchange(a[i]) elif i==2: # 对于:亿、十亿、百亿、千亿位 b.append('yi') exchange(a[i]) for i in range(len(b)-1, -1, -1): # 将列表b逆序输出即可 # 元素之间要空格 if i==len(b)-1: print(b[i], end='') else: print(' %s' % b[i], end='')
0.0分
1 人评分
C语言程序设计教程(第三版)课后习题1.5 (C语言代码)浏览:689 |
简单的a+b (C语言代码)浏览:764 |
C语言程序设计教程(第三版)课后习题7.1 (C语言代码)浏览:1267 |
WU-格式化数据输出 (C++代码)浏览:1312 |
C语言程序设计教程(第三版)课后习题1.5 (C语言代码)浏览:468 |
简单的a+b (C语言代码)浏览:574 |
sizeof的大作用 (C语言代码)浏览:1138 |
1050题解(结构体数组与结构体指针的使用)浏览:1216 |
前10名 (C语言代码)浏览:773 |
A+B for Input-Output Practice (I) (C语言代码)浏览:451 |