-
题目:罗马数字包含以下七种字符:
I,V,X,L,C,D和M。

例如, 罗马数字2写做II,即为两个并列的1。12 写做XII,即为X + II。27写做XXVII,即为XX + V + II。
通常情况下,罗马数字中小的数字在大的数字的右边。但也存在特例,例如4不写做IIII,而是IV。数字1在数字5的左边,所表示的数等于大数5减小数1得到的数值4。同样地,数字9表示为IX。这个特殊的规则只适用于以下六种情况:
I可以放在V (5)和X (10)的左边,来表示4和9。
X可以放在L (50)和C (100)的左边,来表示40和90。
C可以放在D (500)和M (1000)的左边,来表示400和900。
给定一个罗马数字,将其转换成整数。1 -
示例:
# 示例 1
输入: s = "III"
输出: 3
# 示例 2
输入: s = "IV"
输出: 4
# 示例 3
输入: s = "IX"
输出: 9
# 示例 4
输入: s = "LVIII"
输出: 58
解释: L = 50, V= 5, III = 3.
# 示例 5
输入: s = "MCMXCIV"
输出: 1994
解释: M = 1000, CM = 900, XC = 90, IV = 4.
- 解法:
class Solution(object):
def romanToInt(self, s):
"""
:type s: str
:rtype: int
"""
list_roma_common = {
"I": 1,
"V": 5,
"X": 10,
"L": 50,
"C": 100,
"D": 500,
"M": 1000
}
list_roma_special = {
"IV": 4,
"IX": 9,
"XL": 40,
"XC": 90,
"CD": 400,
"CM": 900
}
sum_roma = 0
# 先遍历特殊字符并用空替换
for i in list_roma_special:
if i in s:
s = s.replace(i, '')
sum_roma = sum_roma + list_roma_special[i]
# 遍历剩下的字符相加减
for i in s:
if i in list_roma_common:
sum_roma = sum_roma + list_roma_common[i]
return sum_roma










