leetcode 13.罗马数字转整数

22 阅读1分钟

定义一个哈希表存储罗马数字及对应的整数,直接遍历。字符串中的每个字符,它检查当前字符的值是否小于其后一个字符的值。如果是,则将当前字符的值从总和中减去(表示减法规则);否则,将当前字符的值加到总和中。对于字符串的最后一个字符,由于其后没有字符进行比较,因此总是直接加到总和中。

class Solution {
    public int romanToInt(String s) {
        Map<Character, Integer> map = new HashMap<>();
        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);
        int sum = 0;
        int n = s.length();
        for (int i = 0; i < n; i++) {
            int val = map.get(s.charAt(i));
            if (i < n - 1 && val < map.get(s.charAt(i + 1))) {
                sum -= val;
            } else {
                sum += val;
            }
        }
        return sum;
    }
}