【12】【Python3】整数转罗马数字

算法:

【贪心算法】

ans = ''
for item in character键的集合 from 最大 to 最小:
    num 为 0:
        结束,退出循环
    num 不为 0:
        if item <= num:
            计算需要的个数 cnt = num // item
            更新 num -= cnt * item
            更新 ans += cnt * item 对应的值
        else:
            continue

时间复杂度:仅需遍历一次dict即可结束,故为O(1)。 

空间复杂度:使用的内存不会随着输入整数的大小而改变,故为O(1)。 

代码:

character = {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'}

def romanToInt(num: int) -> str:
    ans = ''
    for item in character.keys():
        if num <= 0:
            break
        if item <= num:
            ans += character[item] * (num // item)
            num -= (num // item) * item
        #  print(ans)
    return ans

代码优化:

def romanToInt(num: int) -> str:
    ans = ''
    for item in character.keys():
        if num <= 0:
            break
        if item <= num:
            cnt, num = divmod(num, item)  # 使用内部函数简化代码(但经测试运行速度不及前一个版本)
            ans += cnt * character[item]
    #  print(ans)
    return ans

 

心得:

1、divmod(a, b) 函数返回值为元组(a // b, a % b)

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值