LeetCode 每日一題 [10] 羅馬數(shù)字轉(zhuǎn)整數(shù)

LeetCode 羅馬數(shù)字轉(zhuǎn)整數(shù) [簡單]

羅馬數(shù)字包含以下七種字符: I, V贺氓, X蔚叨, L,C辙培,D 和 M蔑水。

字符          數(shù)值
I             1
V             5
X             10
L             50
C             100
D             500
M             1000

例如, 羅馬數(shù)字 2 寫做 II 扬蕊,即為兩個(gè)并列的 1搀别。12 寫做 XII ,即為 X + II 尾抑。 27 寫做 XXVII, 即為 XX + V + II 歇父。

通常情況下,羅馬數(shù)字中小的數(shù)字在大的數(shù)字的右邊再愈。但也存在特例榜苫,例如 4 不寫做 IIII,而是 IV翎冲。數(shù)字 1 在數(shù)字 5 的左邊垂睬,所表示的數(shù)等于大數(shù) 5 減小數(shù) 1 得到的數(shù)值 4 。同樣地抗悍,數(shù)字 9 表示為 IX驹饺。這個(gè)特殊的規(guī)則只適用于以下六種情況:

I 可以放在 V (5) 和 X (10) 的左邊,來表示 4 和 9缴渊。
X 可以放在 L (50) 和 C (100) 的左邊赏壹,來表示 40 和 90。
C 可以放在 D (500) 和 M (1000) 的左邊疟暖,來表示 400 和 900卡儒。
給定一個(gè)羅馬數(shù)字,將其轉(zhuǎn)換成整數(shù)俐巴。輸入確保在 1 到 3999 的范圍內(nèi)。

來源:力扣(LeetCode)
鏈接:https://leetcode-cn.com/problems/roman-to-integer

示例 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:

把所有可能的數(shù)據(jù)和對應(yīng)的值存儲(chǔ)到HashMap中硬爆,然后取出目標(biāo)字符串的2位欣舵,然后如果2位不符合就再匹配一位,匹配到了缀磕,就修改位置缘圈。然后數(shù)據(jù)拿出來增加

方法2:

把一個(gè)小值放在大值的左邊劣光,就是做減法,否則為加法.


方法2
代碼實(shí)現(xiàn)
public class LeetCode_10_RomanToInteger {
    private static HashMap<String, Integer> map = new HashMap<>();

    static {
        map.put("I", 1);
        map.put("V", 5);
        map.put("X", 10);
        map.put("L", 50);
        map.put("C", 100);
        map.put("D", 500);
        map.put("M", 1000);
        map.put("IV", 4);
        map.put("XI", 9);
        map.put("XL", 40);
        map.put("CX", 90);
        map.put("CD", 400);
        map.put("MC", 900);
    }

    public static void main(String[] args) {
        String target = "III";
        int res = romanToInt(target);
        System.out.println(res);
    }

    public static int romanToInt02(String s) {
        if (s == null || s.length() == 0) {
            return -1;
        }
        int sum = 0;
        int preNum = getValue(s.charAt(0));
        for (int i = 1; i < s.length(); i++) {
            int num = getValue(s.charAt(i));
            if (preNum < num) {
                sum -= preNum;
            } else {
                sum += preNum;
            }
            preNum = num;
        }
        sum += preNum;
        return sum;
    }

    private static int getValue(char ch) {
        switch (ch) {
            case 'I':
                return 1;
            case 'V':
                return 5;
            case 'X':
                return 10;
            case 'L':
                return 50;
            case 'C':
                return 100;
            case 'D':
                return 500;
            case 'M':
                return 1000;
            default:
                return 0;
        }
    }


    public static int romanToInt(String s) {
        if (s == null || s.length() == 0) {
            return -1;
        }
        if (s.length() == 1) {
            return map.get(s);
        }
        int res = 0;
        for (int i = 0; i < s.length(); ) {
            if (i + 1 < s.length() && map.containsKey(s.substring(i, i + 2))) {
                res += map.get(s.substring(i, i + 2));
                i += 2;
            } else {
                res += map.get(s.substring(i, i + 1));
                i += 1;
            }
        }
        return res;
    }
}

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末糟把,一起剝皮案震驚了整個(gè)濱河市绢涡,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌遣疯,老刑警劉巖雄可,帶你破解...
    沈念sama閱讀 217,277評論 6 503
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異缠犀,居然都是意外死亡数苫,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,689評論 3 393
  • 文/潘曉璐 我一進(jìn)店門辨液,熙熙樓的掌柜王于貴愁眉苦臉地迎上來虐急,“玉大人,你說我怎么就攤上這事滔迈≈褂酰” “怎么了?”我有些...
    開封第一講書人閱讀 163,624評論 0 353
  • 文/不壞的土叔 我叫張陵燎悍,是天一觀的道長敬惦。 經(jīng)常有香客問我,道長间涵,這世上最難降的妖魔是什么仁热? 我笑而不...
    開封第一講書人閱讀 58,356評論 1 293
  • 正文 為了忘掉前任,我火速辦了婚禮勾哩,結(jié)果婚禮上抗蠢,老公的妹妹穿的比我還像新娘。我一直安慰自己思劳,他們只是感情好迅矛,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,402評論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著潜叛,像睡著了一般秽褒。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上威兜,一...
    開封第一講書人閱讀 51,292評論 1 301
  • 那天销斟,我揣著相機(jī)與錄音,去河邊找鬼椒舵。 笑死蚂踊,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的笔宿。 我是一名探鬼主播犁钟,決...
    沈念sama閱讀 40,135評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼棱诱,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了涝动?” 一聲冷哼從身側(cè)響起迈勋,我...
    開封第一講書人閱讀 38,992評論 0 275
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎醋粟,沒想到半個(gè)月后靡菇,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,429評論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡昔穴,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,636評論 3 334
  • 正文 我和宋清朗相戀三年镰官,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片吗货。...
    茶點(diǎn)故事閱讀 39,785評論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡泳唠,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出宙搬,到底是詐尸還是另有隱情笨腥,我是刑警寧澤,帶...
    沈念sama閱讀 35,492評論 5 345
  • 正文 年R本政府宣布勇垛,位于F島的核電站脖母,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏闲孤。R本人自食惡果不足惜谆级,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,092評論 3 328
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望讼积。 院中可真熱鬧肥照,春花似錦、人聲如沸勤众。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,723評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽们颜。三九已至吕朵,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間窥突,已是汗流浹背努溃。 一陣腳步聲響...
    開封第一講書人閱讀 32,858評論 1 269
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留阻问,地道東北人茅坛。 一個(gè)月前我還...
    沈念sama閱讀 47,891評論 2 370
  • 正文 我出身青樓,卻偏偏與公主長得像则拷,于是被迫代替她去往敵國和親贡蓖。 傳聞我的和親對象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,713評論 2 354