Python 如何將integer轉化為羅馬數(3999以內)

1,在Python中將integer數轉化為羅馬數

說明:在羅馬數中(3999以內),和阿拉伯數字相似,可以把它分解為個位,十位,百位,千位,然後相加(我是這麼認為的+_+),所以這樣就簡單瞭,隻需把不同位數的基數表示出來相加即可。

例如:

阿拉伯數字為124=100+20+4,

羅馬數字為字符串相加‘CXXIV’=‘C’+‘XX’+IV”

按此規律見代碼分析:

註意: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'}  #創建一個匹配字典,註意   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 的范圍內

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()

以上為個人經驗,希望能給大傢一個參考,也希望大傢多多支持WalkonNet。

推薦閱讀: