Python 如何將integer轉化為羅馬數(shù)(3999以內(nèi))
說明:在羅馬數(shù)中(3999以內(nèi)),和阿拉伯數(shù)字相似,可以把它分解為個位,十位,百位,千位,然后相加(我是這么認為的+_+),所以這樣就簡單了,只需把不同位數(shù)的基數(shù)表示出來相加即可。
例如:阿拉伯數(shù)字為124=100+20+4,
羅馬數(shù)字為字符串相加‘CXXIV’=‘C’+‘XX’+IV’’
按此規(guī)律見代碼分析:
注意:4,9,40,90,400,900得用大的減小的表示(因為相同字符相連不超過三個)
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 s2,Python 給定一個整數(shù),將其轉為羅馬數(shù)字
輸入確保在 1 到 3999 的范圍內(nèi)
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 romandef main(): text = input('輸入整數(shù)') print(change(text))main()
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持好吧啦網(wǎng)。
相關文章:
