今天做力扣罗马数字转整数题时,很明显感觉到replace()方法的给力之处。下面我将通过这道题来为大家介绍和展示replace()的妙不可言。
replace()
Python replace() 方法把字符串中的 old(旧字符串) 替换成 new(新字符串),如果指定第三个参数max,则替换不超过 max 次。
语法: str.replace(old, new[, max])
参数 | 描述 |
---|---|
old | 将被替换的子字符串 |
new | 新字符串,用于替换old子字符串 |
max | 可选字符串, 替换不超过 max 次 |
str = "chenkk like coding wo wo wo wo"
print (str.replace("like", "likes"))
print (str.replace("wo", "wow", 3))
#Output
#chenkk likes coding wo wo wo wo
#chenkk like coding wow wow wow wo
题目:罗马数字转整数
罗马数字包含以下七种字符: I, V, X, L,C,D 和 M。
字符 数值
I 1
V 5
X 10
L 50
C 100
D 500
M 1000
例如, 罗马数字 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。
给定一个罗马数字,将其转换成整数。
这道题,很简单的算法是:首先将所有组合放在字典中并赋予其专属键值,再将字符串中的和I、X、C组合的小字符串替换为字典中的新字符,最后遍历累加字典得最终结果。而此次的关键就是replace() 函数的熟练使用。
代码如下:
s = input("请输入一串罗马数字:")
sum = 0
list = {'M':1000,'a':900,'D':500,'b':400,'C':100,'c':90,'L':50,'d':40,'X':10,'e':9,'V':5,'f':4,'I':1}
s = s.replace('CM','a')
s = s.replace('CD','b')
s = s.replace('XC','c')
s = s.replace('XL','d')
s = s.replace('IX','e')
s = s.replace('IV','f')
for i in s:
sum += list[i]
print(sum)
#
#请输入一串罗马数字:VIII
#8
#请输入一串罗马数字:LVIII
#58
#请输入一串罗马数字:MCMXCIV
#1994