zoukankan      html  css  js  c++  java
  • 0013 罗马数字转整数

    0013 罗马数字转整数

    """
    Roman numerals are represented by seven different symbols: I, V, X, L, C, D and M.
    
    Symbol       Value
    I             1
    V             5
    X             10
    L             50
    C             100
    D             500
    M             1000
    For example, two is written as II in Roman numeral, just two one's added together. Twelve is written as, XII, which is simply X + II. The number twenty seven is written as XXVII, which is XX + V + II.
    
    Roman numerals are usually written largest to smallest from left to right. However, the numeral for four is not IIII. Instead, the number four is written as IV. Because the one is before the five we subtract it making four. The same principle applies to the number nine, which is written as IX. There are six instances where subtraction is used:
    
    I can be placed before V (5) and X (10) to make 4 and 9. 
    X can be placed before L (50) and C (100) to make 40 and 90. 
    C can be placed before D (500) and M (1000) to make 400 and 900.
    Given a roman numeral, convert it to an integer. Input is guaranteed to be within the range from 1 to 3999. 
    
    罗马数字包含以下七种字符: 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。
    给定一个罗马数字,将其转换成整数。输入确保在 1 到 3999 的范围内。
    
    示例 1:
    输入: "III"
    输出: 3
    
    示例 2:
    输入: "IV"
    输出: 4
    
    示例 3:
    输入: "IX"
    输出: 9
    
    示例 4:
    输入: "LVIII"
    输出: 58
    解释: L = 50, V= 5, III = 3.
    
    示例 5:
    输入: "MCMXCIV"
    输出: 1994
    解释: M = 1000, CM = 900, XC = 90, IV = 4.
    
    来源:力扣(LeetCode)
    链接:https://leetcode-cn.com/problems/roman-to-integer
    著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
    """
    
    """
    想法:
        只要前一个字符所对应的数字小于后面那个字符对应的数字,就将其置为负数,
        例,CM代表900,因为第一个字符C对应的数字为100,第二个字符M对应的数字为1000,
        第二个数字比第一个数字大,那么就将第一个字符C对应的数字置为负数,即-100。
        将所有的字符转化完毕之后,全部相加就得到了最终的值。
        
        ps:需要注意索引越界问题,最后一个字符是不需要判断的。
        
    """
    
    class Solution:
        def romanToInt(self, s: str) -> int:
            t_d = {
                "I": 1,
                "V": 5,
                "X": 10,
                "L": 50,
                "C": 100,
                "D": 500,
                "M": 1000,
            }
            num = 0
            for i in range(len(s)):
                tmp = t_d[s[i]]
                if i < len(s)-1 and t_d[s[i]] < t_d[s[i+1]]:
                    tmp = -t_d[s[i]]
                num += tmp
            return num
    
  • 相关阅读:
    仿联想商城laravel实战---6、自建配置文件和缓存(如何读取自己创建的配置文件的信息)
    php中相对路径和绝对路径如何使用(详解)
    英语影视台词---绿皮书(2)(利普 我以为你要把那家伙打死了)
    仿联想商城laravel实战---5、无刷新的增删改查(动态页面更新的三种方式(html))
    英语发音规则---ea字母组合发音规律
    英语发音规则---ir字母组合发音规律
    仿联想商城laravel实战---4、验证(lavarel的表单验证如何使用)
    android adb 不同的方式使用特定的解释
    Spring aop 小例子demo
    SPOJ 15. The Shortest Path 堆优化Dijsktra
  • 原文地址:https://www.cnblogs.com/xt12321/p/11664789.html
Copyright © 2011-2022 走看看