leetcode13_ローマ数字回転整数

4119 ワード

ローマ数字には、I、V、X、L、C、D、Mの7文字が含まれています.
文字値I 1 V 5 X 10 L 50 C 100 D 500 M 1000は、例えば、ローマ数字2をIIと書くと、2つの並列の1となる.12はXIIと書きます.つまりX+IIです.27 XXVIIと書くと、XX+V+IIとなります.
通常、ローマ数字の中で小さい数字は大きな数字の右側にあります.しかし、例えば4はIIIではなくIVと書くという特例もある.数字1は数字5の左側にあり、表す数は大数5から小数1を減らした数値4に等しい.同様に、数字9はIXとして表される.この特殊なルールは、次の6つの場合にのみ適用されます.
IはV(5)とX(10)の左側に置いて4と9を表すことができる.XはL(50)とC(100)の左側に置いて40と90を表すことができる.CはD(500)とM(1000)の左側に置いて400と900を表すことができる.ローマ数字を指定し、整数に変換します.入力は1~3999の範囲であることを確認します.
例1:入力:III出力:3例2:
入力:IV出力:4例3:
入力:IX出力:9例4:
入力:「LVIII」出力:58解釈:L=50,V=5,III=3.例5:
入力:「MCMXCIV」出力:1994解釈:M=1000,CM=900,XC=90,IV=4.
この問題は実は何も言うことはありません.やり方を覚えてください.1つは速いポインタで、1つは総括の法則です:それはもし1つの大きい数が1つの小さい数の右側にあるならば、彼らの2つは合併して1つの数の“大きい-小さい”を表します;ある数の右の数がそれより小さい場合、この右の数は常に結果に加算されます.
class Solution:
    def romanToInt(self, s: str) -> int:
        mydict = {'I':1, 'V':5, 'X':10, 'L':50, 
        'C':100, 'D':500, 'M':1000}
        pre = 0
        res = 0
        for i in s:
            cur = mydict[i]
            #                ,                
            if cur <= pre:
                res += cur
            #        cur pre ,             res 
            #      cur   cur-pre     res ,
            #         ,1:           , -pre
            # 2:         cur-pre,      cur-2pre
            else:
                res += (cur - 2*pre)
            pre = cur
        return res