13 leetcode - Roman to Integer
来源:互联网 发布:富贵电玩城源码 编辑:程序博客网 时间:2024/06/02 02:02
#!/usr/bin/python# -*- coding: utf-8 -*-'''罗马数字->整数'''class Solution(object): def romanToInt1(self, s):#暴力法= = """ :type s: str :rtype: int """ if not s: return 0 a = ["I", "II", "III", "IV", "V", "VI", "VII", "VIII", "IX", "X", "XX", "XXX", "XL", "L", "LX", "LXX", "LXXX", "XC", "C", "CC", "CCC", "CD", "D", "DC", "DCC", "DCCC", "CM", "M", "MM", "MMM"] a.reverse() b = range(1,10) + range(10,100,10) + range(100,1000,100) + [1000,2000,3000] b.reverse() length = len(s) result = 0 start = 0 for index,val in enumerate(a): if val == s[start:start + len(val)]: result += b[index] start += len(val) if start >= length: break return result def romanToInt2(self, s):#查看罗马数字规律 if not s: return 0 d = {'I':1,'V':5,'X':10,'L':50,'C':100,'D':500,'M':1000} result = d[s[0]] for index,val in enumerate(s[1:]): pre = s[index] #代表前一个数 if d[pre] >= d[val]: result += d[val] else: result = result - 2 * d[pre] + d[val] return resultif __name__ == "__main__": s = Solution() print s.romanToInt2("MCMXCVI")
罗马数字有如下符号:
计数规则:
1. 相同的数字连写,所表示的数等于这些数字相加得到的数,例如:III = 3;
2. 小的数字在大的数字右边,所表示的数等于这些数字相加得到的数,例如:VIII = 8;
3. 小的数字,限于(I、X和C中的一个)在大的数字左边,所表示的数等于大数减去小数所得的数,例如:IV = 4;
4. 当小的数字出现在大的数字左边时,只限出现一次,如IIV则不合法;而且小的这个数只能比大的数小一个级别,如IX不合法;
5. 正常使用时,连续的数字重复不得超过三次;
6. 在一个数的上面画横线,表示这个数扩大1000倍(本题只考虑3999以内的数,所以用不到这条规则);
总结规律:
从前向后遍历罗马数字,如果某个数比前一个数小,则加上该数。反之,减去前一个数的两倍然后加上该数.
0 0
- leetcode-13:Roman to Integer
- leetcode 13 Roman to Integer
- Leetcode【13】:Roman to Integer
- [leetcode 13] Roman to Integer
- [Leetcode] 13 - Roman to Integer
- LeetCode | #13 Roman to Integer
- leetcode.13---------Roman to Integer
- leetCode #13 Roman to Integer
- leetcode-13 Roman to Integer
- leetcode 13 Roman to Integer
- LeetCode 13 Roman to Integer
- LeetCode 13 - Roman to Integer
- leetcode 13 -- Roman to Integer
- LeetCode 13:"Roman to Integer"
- LeetCode---(13)Roman to Integer
- leetcode-13Roman to Integer
- leetcode 13: Roman to Integer
- Leetcode 13 Roman to Integer
- Android项目之android SDK视频播放与vitamio视频播放
- SAP销售订单-订单组合
- 在spring中引入commons-logging.jar包的目的
- ActiveMQ单机部署zookeeper+levelDB集群
- 业务场景驱动的服务型CMDB
- 13 leetcode - Roman to Integer
- iOS 计步器(系统)
- 用QUERY作为另一个query变量的输入
- bzoj 4580: [Usaco2016 Open]248 (dp)
- Nginx Tomcat负载均衡
- C++11关键字auto如何得到const迭代器
- Unity3D游戏开发之详解 Animation类和Animator类
- 数字三角形
- tuxedo问题描述