python解题:;整数转罗马数字

def luomashuzi(nums: int) -> str:
    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'}
    res = ''
    for key in hashmap:
        if nums // key != 0:
            count = nums // key
            res += hashmap[key] * count
            nums %= key
    return res

---------------------------------------------------------------------------------------------------------------------------

解题思路:

贪心算法:我们每次尽量使用最大的数来表示。 比如对于 1479 这个数,如果我们每次尽量用最大的数来表示,依次选 1000,400,70,9,会得到正确结果 MCDLXXIX。

所以,我们将哈希表按照从大到小的顺序排列,然后遍历哈希表,直到表示完整个输入。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值