ericpuwang

整数转罗马数字

https://leetcode.cn/problems/integer-to-roman/

七个不同的符号代表罗马数字,其值如下:

符号
I 1
V 5
X 10
L 50
C 100
D 500
M 1000

罗马数字是通过添加从最高到最低的小数位值的转换而形成的。将小数位值转换为罗马数字有以下规则:

示例1

输入:num = 3749
输出: "MMMDCCXLIX"

解释:
3000 = MMM 由于 1000 (M) + 1000 (M) + 1000 (M)
 700 = DCC 由于 500 (D) + 100 (C) + 100 (C)
  40 = XL 由于 50 (L) 减 10 (X)
   9 = IX 由于 10 (X) 减 1 (I)
注意:49 不是 50 (L) 减 1 (I) 因为转换是基于小数位

示例2

输入:num = 58
输出:"LVIII"

解释:
50 = L
 8 = VIII

示例3

输入:num = 1994
输出:"MCMXCIV"

解释:
1000 = M
 900 = CM
  90 = XC
   4 = IV

提示

class Solution:
    def intToRoman(self, num: int) -> str:
        res = ""
        hashmap = {
            1000: 'M',
            900: 'CM',
            500: 'D',
            400: 'CD',
            100: 'C',
            90: 'XC',
            50: 'L',
            40: 'XL',
            10: 'X',
            9: 'IX',
            5: 'V',
            4: 'IV',
            1: 'I'
        }
        # python3.7+: 按照插入顺序保留
        # python3.6及以下: 乱序
        for key in hashmap:
            if num // key != 0:
                count = num // key
                res += hashmap[key] * count
                num -= count * key
        return res