羅馬數字包含以下七種字符:?I
,?V
,?X
,?L
,C
,D
?和?M
。
字符 數值 I 1 V 5 X 10 L 50 C 100 D 500 M 1000
例如, 羅馬數字 2
寫做?II
?,即為兩個并列的 1 。12
寫做?XII
?,即為?X
?+?II
?。 27
寫做??XXVII
, 即為?XX
?+?V
?+?II
?。
通常情況下,羅馬數字中小的數字在大的數字的右邊。但也存在特例,例如 4 不寫做?IIII
,而是?IV
。數字 1 在數字 5 的左邊,所表示的數等于大數 5 減小數 1 得到的數值 4 。同樣地,數字 9 表示為?IX
。這個特殊的規則只適用于以下六種情況:
I
?可以放在?V
?(5) 和?X
?(10) 的左邊,來表示 4 和 9。X
?可以放在?L
?(50) 和?C
?(100) 的左邊,來表示 40 和?90。?C
?可以放在?D
?(500) 和?M
?(1000) 的左邊,來表示?400 和?900。
給定一個羅馬數字,將其轉換成整數。
示例?1:
輸入:?s = "III" 輸出: 3
示例?2:
輸入:?s = "IV" 輸出: 4
示例?3:
輸入:?s = "IX" 輸出: 9
示例?4:
輸入:?s = "LVIII" 輸出: 58 解釋: L = 50, V= 5, III = 3.
示例?5:
輸入:?s = "MCMXCIV" 輸出: 1994 解釋: M = 1000, CM = 900, XC = 90, IV = 4.
提示:
1 <= s.length <= 15
s
僅含字符('I', 'V', 'X', 'L', 'C', 'D', 'M')
- 題目數據保證
s
是一個有效的羅馬數字,且表示整數在范圍[1, 3999]
內 - 題目所給測試用例皆符合羅馬數字書寫規則,不會出現跨位等情況。
- IL 和 IM 這樣的例子并不符合題目要求,49 應該寫作 XLIX,999 應該寫作 CMXCIX 。
- 關于羅馬數字的詳盡書寫規則,可以參考 羅馬數字 - Mathematics?。
代碼:
class Solution {public int romanToInt(String s) {s = s.replace("IV", "a");s = s.replace("IX", "b");s = s.replace("XL", "c");s = s.replace("XC", "d");s = s.replace("CD", "e");s = s.replace("CM", "f");int result = 0;for(int i = 0; i < s.length(); i++){result += which(s.charAt(i));}return result;}public int which(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;case 'a' : return 4;case 'b' : return 9;case 'c' : return 40;case 'd' : return 90;case 'e' : return 400;case 'f' : return 900;}return 0;}
}