1,在Python中将integer数转化为罗马数
说明:在罗马数中(3999以内),和阿拉伯数字相似,可以把它分解为个位,十位,百位,千位,然后相加(我是这么认为的+_+),所以这样就简单了,只需把不同位数的基数表示出来相加即可。
例如:
阿拉伯数字为124=100+20+4,
罗马数字为字符串相加‘CXXIV'=‘C'+‘XX'+IV''
按此规律见代码分析:
注意:4,9,40,90,400,900得用大的减小的表示(因为相同字符相连不超过三个)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
|
def trans(n):
Dict = { 0 :' ',1:' I ',5:' V ',10:' X ',50:' L ',100:' C ',500:' D ',1000:' M '} #创建一个匹配字典,注意 0:‘' 是小细节,帮助处理位系数为 0 的情况
num_str = str (n)
s = ''
for i in range ( len (num_str)): #按位次循环相加
j = len (num_str) - 1 - i #字符是从左到右,10**j表示所在位次
num = int (num_str[i])
if num = = 0 : #
s + = ''
else :
N = num / / 5 #取整,用来判断是0+ 还是5+, 还是5-,还是10-
M = num % 5 #取余,用来判断相同相连的个数,1-3用加,4用减
if M = = 4 : #,9,40,90,400,900的情况
s + = Dict [ 10 * * (j)] + Dict [(N + 1 ) * 5 * 10 * * (j)] #右减左
else :
s + = Dict [N * 5 * 10 * * (j)] + Dict [ 10 * * (j)] * M #左加右
return s
|
2,Python 给定一个整数,将其转为罗马数字
输入确保在 1 到 3999 的范围内
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
|
def change(text):
num = int (text)
# 数组内数据位置不要改,不然就不能从高位开始对比
checkNum = [ 1000 , 900 , 500 , 400 , 100 , 90 , 50 , 40 , 10 , 9 , 5 , 4 , 1 ]
str = [ "M" , "CM" , "D" , "CD" , "C" , "XC" , "L" , "XL" , "X" , "IX" , "V" , "IV" , "I" ]
roman = ""
i = 0
#对比完,减去已对比数组,对比数组下个值
while (num ! = 0 ) :
if (num > = checkNum[i]):
num - = checkNum[i]
roman + = str [i]
else :
i + = 1
return roman
def main():
text = input ( "输入整数" )
print (change(text))
main()
|
以上为个人经验,希望能给大家一个参考,也希望大家多多支持服务器之家。
原文链接:https://blog.csdn.net/qq_43571494/article/details/89715862