說明:在羅馬數(shù)中(3999以內(nèi)),和阿拉伯數(shù)字相似,可以把它分解為個位,十位,百位,千位,然后相加(我是這么認為的+_+),所以這樣就簡單了,只需把不同位數(shù)的基數(shù)表示出來相加即可。
def trans(n):
Dict = {0:'',1:'I',5:'V',10:'X',50:'L',100:'C',500:'D',1000:'M'} #創(chuàng)建一個匹配字典,注意 0:‘' 是小細節(jié),幫助處理位系數(shù)為0的情況
num_str = str(n)
s = ''
for i in range(len(num_str)): #按位次循環(huán)相加
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 #取余,用來判斷相同相連的個數(shù),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)
# 數(shù)組內(nèi)數(shù)據(jù)位置不要改,不然就不能從高位開始對比
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
#對比完,減去已對比數(shù)組,對比數(shù)組下個值
while (num != 0) :
if (num >= checkNum[i]):
num -= checkNum[i]
roman += str[i]
else:
i+=1
return roman
def main():
text = input("輸入整數(shù)")
print(change(text))
main()