ローマ数字を普通のアラビア数字に変換する
ローマ数字、私达はいくつかのテレビの中であるいは现実の生活の中ですべてかつて见たことがあって、最近、Pythonを学ぶ时、ローマ数字の解说にも出会って、そこでついでに1つの小さいプログラムを书いてローマ数字から私达の日常生活の普通の数字の间の変换の小さい関数を练习します.まず、ローマ数字の潜在的な法則を理解してみましょう.ローマ数字の中で、7つの異なるアルファベットを繰り返したり組み合わせたりして、いろいろな数字を表現します.I=1 V=5 X=10 L=50 C=100 D=500 M=1000その組み合わせ関係は、上の文字が最大3回連続して使用できることです.例えば、4、ローマ数字はIIIではなくIVであるべきで、3つの組み合わせを超える場合は、低高の組み合わせを使用します.4はIとVの組み合わせです.Iは1を表し、Vは5関数の使用方法を表します.getRomanNum('MDCCCLXXXVIII')は1888を獲得します.
PythonCode:
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'