zoukankan      html  css  js  c++  java
  • [LeetCode]题解(python):013-Roman to Integer

    题目来源:

    https://leetcode.com/problems/roman-to-integer/


    题意分析:

            这道题目和上一题目相反,是将罗马数字转化成阿拉伯数字。


    题目思路:

           只要知道罗马数字和阿拉伯数字之间是怎么转换的就可以了。先做一个字符和数值对应的字典,{'I':1,'V':5,'X':10,'L':50,'C':100,'D':500,'M':1000};如果发现输入的字符串后一位比前一位小,则是出现4,9之类的,那么将前一个字符对应的数值减去两次就可以了。


    代码(python):

     1 class Solution(object):
     2     def romanToInt(self, s):
     3         """
     4         :type s: str
     5         :rtype: int
     6         """
     7         d = {'I':1,'V':5,'X':10,'L':50,'C':100,'D':500,'M':1000}
     8         ans = 0
     9         size = len(s)
    10         i = 0
    11         while i < size:
    12             if i > 0 and d[s[i]] > d[s[i - 1]]:
    13                 ans += d[s[i]] - 2 * d[s[i - 1]]
    14             else:
    15                 ans += d[s[i]]
    16             i += 1
    17         return ans
    View Code

     转载请注明出处:http://www.cnblogs.com/chruny/p/4817835.html

  • 相关阅读:
    Manjaro中添加gitee的公钥部署
    另类的linux系统
    mac的快捷键flykey应用
    tidb总览
    raft算法
    tidb的tidb
    tidb的tikv
    tidb的pd
    切尔诺贝利事故
    血钻
  • 原文地址:https://www.cnblogs.com/chruny/p/4817835.html
Copyright © 2011-2022 走看看