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