leedcode 罗马数字转整数

复制代码
class Solution:
    def romanToInt(self, s: str) -> int:
        num_convert = {'I': 1, 'V': 5, 'X':10,'L':50,'C':100,'D':500,'M':1000}
        s_len=len(s)
        count=0
        for i in range(s_len):
            if s[i] in num_convert:
                if i==s_len-1:
                    count+=num_convert[s[i]]
                    continue
                elif s[i]=='I' and s[i+1]=='V':
                    count-=num_convert[s[i]]
                    continue
                elif s[i]=='I' and s[i+1]=='X':
                    count-=num_convert[s[i]]

                    continue
                elif s[i]=='X' and s[i+1]=='L':
                    count-=num_convert[s[i]]
                    continue
                elif s[i]=='X' and s[i+1]=='C':
                    count-=num_convert[s[i]]
                    continue
                elif s[i]=='C' and s[i+1]=='D':
                    count-=num_convert[s[i]]
                    continue
                elif s[i]=='C' and s[i+1]=='M':
                    count-=num_convert[s[i]]
                    continue
                else:
                    count+=num_convert[s[i]]
        return count

s = "MCMXCIV"
sol = Solution().romanToInt(s)
print(sol)
复制代码

 

posted @   Junior_bond  阅读(2)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· winform 绘制太阳,地球,月球 运作规律
· AI与.NET技术实操系列(五):向量存储与相似性搜索在 .NET 中的实现
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 上周热点回顾(3.3-3.9)
点击右上角即可分享
微信分享提示