说明:在罗马数中(3999以内),和阿拉伯数字相似,可以把它分解为个位,十位,百位,千位,然后相加(我是这么认为的+_+),所以这样就简单了,只需把不同位数的基数表示出来相加即可。
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
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()