leetcode 418 整数转罗马数字

描述

给定一个整数,将其转换成罗马数字。

保证给定的整数在1到3999的范围内。
样例 1:

输入: 1
输出: “I”

样例 2:

输入: 99
输出: “XCIX”

class Solution(object):
    def intToRoman(self, num):
        """
        :type num: int
        :rtype: str
        """
        digit = [1000,900,500,400,100,90,50,10,9,5,4,1]
        mapping = {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 i in digit:
            res += (num //i) * mapping[i]
            num -= i * (num // i)
            if num == 0:
                break
        return res
c=Solution()
d=c.intToRoman(2)
print(d)

输出结果:II

说明digit 不能为这样 [1,4,5,9,10,40,50,90,100,400,500,900,1000]
因为就和计数一样,111,读作是111/100+11/10+1/1。从大到小。

因为罗马数字,取值见表

字符 数值
I 1
V 5
X 10
L 50
C 100
D 500
M 1000

#罗马数字
I,II,III,IV,V=1,2,3,4,5。
1,4,5有区别。所以digit = [1000,900,500,400,100,90,50,10,9,5,4,1]

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

总裁余(余登武)

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值