将罗马数字转换成普通的阿拉伯数字

  罗马数字,我们在某些电视中或者现实生活中都曾经看到过,近日,学习Python时,也遇到了罗马数字的解说,于是顺便写了一个小程序来练习罗马数字到我们日常生活普通数字之间的转换的小函数。
  首先,咱们了解一下,罗马数字的潜在法则,
  在罗马数字中,利用7个不同字母进行重复或者组合来表达各式各样的数字。 
I = 1
V
= 5
X = 10
L
= 50
C
= 100
D
= 500
M
= 1000
其组合关系是:
 上面的字符最多能同时连续的使用三次
 比如:4,罗马数字就应该是IV,而不是IIII,超过三个组合时,就要使用低高组合,4就是I和V的组合,I表示1,V表示5

函数使用方法:
  getRomanNum('MDCCCLXXXVIII')就会获得1888

   

 

PythonCode:
def getRomanNum(RomanStr):
 """Roman numerals will be converted into digital,RomanStr is a RomanString"""
     import re
     if re.search('^M{0,4}(CM|CD|D?C{0,3})(XC|XL|L?X{0,3})(IX|IV|V?I{0,3})$',RomanStr)!=None:
         NumDic = {"pattern":"","retNum":0}
         RomanPattern = {
             "0":('','','','M'),
             "1":('CM','CD','D','C',100),
             "2":('XC','XL','L','X',10),
             "3":('IX','IV','V','I',1)
             }    
         i = 3
         NumItems = sorted(RomanPattern.items())
         for RomanItem in NumItems:
             if RomanItem[0] != '0':
                 patstr = NumDic["pattern"].join(['',RomanItem[1][0]])
                 if re.search(patstr,RomanStr) != None:
                     NumDic["retNum"] += 9*RomanItem[1][4]
                     NumDic["pattern"] = patstr
                 else:
                     patstr = NumDic["pattern"].join(['',RomanItem[1][1]])
                     if re.search(patstr,RomanStr) != None:
                         NumDic["retNum"] += 4*RomanItem[1][4]
                         NumDic["pattern"] = patstr
                     else:
                         patstr = NumDic["pattern"].join(['',RomanItem[1][2]])
                         if re.search(patstr,RomanStr) != None:
                             NumDic["retNum"] += 5*RomanItem[1][4]
                             NumDic["pattern"] = patstr
             if NumDic["pattern"] == '':
                 NumDic["pattern"] = '^'
             tempstr = ''
             sum = 0
             for k in range(0,4):
                 pstr = RomanItem[1][3].join(['','{']).join(['',str(k)]).join(['','}'])
                 patstr = NumDic["pattern"].join(['',pstr])
                 if re.search(patstr,RomanStr) != None:
                     sum = k*(10**i)
                     tempstr = patstr
             if tempstr <> '':
                 NumDic["pattern"] = tempstr
             else:
                 NumDic["pattern"] = patstr
             NumDic['retNum'] += sum
             i -= 1
         return NumDic['retNum']
     else:
         print 'String is not a valid Roman numerals'
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 10
    评论
评论 10
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值