Python | Leetcode Python题解之第13题罗马数字转整数

题目:

题解:

python 复制代码
class Solution:

    SYMBOL_VALUES = {
        'I': 1,
        'V': 5,
        'X': 10,
        'L': 50,
        'C': 100,
        'D': 500,
        'M': 1000,
    }

    def romanToInt(self, s: str) -> int:
        ans = 0
        n = len(s)
        for i, ch in enumerate(s):
            value = Solution.SYMBOL_VALUES[ch]
            if i < n - 1 and value < Solution.SYMBOL_VALUES[s[i + 1]]:
                ans -= value
            else:
                ans += value
        return ans
相关推荐
哈里谢顿5 小时前
Django 应用 OOM(Out of Memory)故障的定位思路和排查方法
python·django
甄心爱学习5 小时前
【python】获取所有长度为 k 的二进制字符串
python·算法
iAkuya5 小时前
(leetcode)力扣100 76数据流的中位数(堆)
算法·leetcode·职场和发展
tuotali20266 小时前
氢气压缩机技术规范亲测案例分享
人工智能·python
嫂子的姐夫6 小时前
030-扣代码:湖北图书馆登录
爬虫·python·逆向
王老师青少年编程6 小时前
2020年信奥赛C++提高组csp-s初赛真题及答案解析(阅读程序第2题)
c++·题解·真题·初赛·信奥赛·csp-s·提高组
a1117767 小时前
EasyVtuber(或其衍生/增强版本)的虚拟主播(Vtuber)面部动画生成与直播解决方案
python·虚拟主播
lintax7 小时前
计算pi值-积分法
python·算法·计算π·积分法
小凯123457 小时前
pytest框架-详解(学习pytest框架这一篇就够了)
python·学习·pytest
逻极7 小时前
pytest 入门指南:Python 测试框架从零到一(2025 实战版)
开发语言·python·pytest