Python 如何將integer轉(zhuǎn)化為羅馬數(shù)(3999以內(nèi))
說明:在羅馬數(shù)中(3999以內(nèi)),和阿拉伯?dāng)?shù)字相似,可以把它分解為個(gè)位,十位,百位,千位,然后相加(我是這么認(rèn)為的+_+),所以這樣就簡單了,只需把不同位數(shù)的基數(shù)表示出來相加即可。
例如:阿拉伯?dāng)?shù)字為124=100+20+4,
羅馬數(shù)字為字符串相加‘CXXIV’=‘C’+‘XX’+IV’’
按此規(guī)律見代碼分析:
注意:4,9,40,90,400,900得用大的減小的表示(因?yàn)橄嗤址噙B不超過三個(gè))
def trans(n): Dict = {0:’’,1:’I’,5:’V’,10:’X’,50:’L’,100:’C’,500:’D’,1000:’M’} #創(chuàng)建一個(gè)匹配字典,注意 0:‘’ 是小細(xì)節(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 #取余,用來判斷相同相連的個(gè)數(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 給定一個(gè)整數(shù),將其轉(zhuǎn)為羅馬數(shù)字
輸入確保在 1 到 3999 的范圍內(nèi)
def change(text):num=int(text)# 數(shù)組內(nèi)數(shù)據(jù)位置不要改,不然就不能從高位開始對(duì)比 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 #對(duì)比完,減去已對(duì)比數(shù)組,對(duì)比數(shù)組下個(gè)值 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()
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持好吧啦網(wǎng)。
相關(guān)文章:
1. python GUI庫圖形界面開發(fā)之PyQt5動(dòng)態(tài)(可拖動(dòng)控件大小)布局控件QSplitter詳細(xì)使用方法與實(shí)例2. ASP動(dòng)態(tài)include文件3. 概述IE和SQL2k開發(fā)一個(gè)XML聊天程序4. ASP將數(shù)字轉(zhuǎn)中文數(shù)字(大寫金額)的函數(shù)5. js開發(fā)中的頁面、屏幕、瀏覽器的位置原理(高度寬度)說明講解(附圖)6. CSS清除浮動(dòng)方法匯總7. 不要在HTML中濫用div8. vue跳轉(zhuǎn)頁面常用的幾種方法匯總9. CSS3實(shí)例分享之多重背景的實(shí)現(xiàn)(Multiple backgrounds)10. XML入門的常見問題(三)
