[LeetCode] 13. Roman to Integer 罗马数字转为整数
Roman numerals are represented by seven different symbols: I
, V
, X
, L
, C
, D
and M
.
Symbol Value I 1 V 5 X 10 L 50 C 100 D 500 M 1000
For example, two is written as II
in Roman numeral, just two one's added together. Twelve is written as, XII
, which is simply X
+ II
. The number twenty seven is written as XXVII
, which is XX
+ V
+ II
.
Roman numerals are usually written largest to smallest from left to right. However, the numeral for four is not IIII
. Instead, the number four is written as IV
. Because the one is before the five we subtract it making four. The same principle applies to the number nine, which is written as IX
. There are six instances where subtraction is used:
I
can be placed beforeV
(5) andX
(10) to make 4 and 9.X
can be placed beforeL
(50) andC
(100) to make 40 and 90.C
can be placed beforeD
(500) andM
(1000) to make 400 and 900.
Given a roman numeral, convert it to an integer. Input is guaranteed to be within the range from 1 to 3999.
Example 1:
Input: "III" Output: 3
Example 2:
Input: "IV" Output: 4
Example 3:
Input: "IX" Output: 9
Example 4:
Input: "LVIII" Output: 58 Explanation: L = 50, V= 5, III = 3.
Example 5:
Input: "MCMXCIV" Output: 1994 Explanation: M = 1000, CM = 900, XC = 90 and IV = 4.
12. Integer to Roman 的拓展,反过来转换,将罗马数字转为整数。
解法:对比s[i]和s[i+1]的罗马数字对应的数字的大小,如果s[i]小于s[i+1]则是出现9的情况,减去此数值。其它情况均累加相对应的数值。
Java:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 | public int romanToInt(String s) { int sum= 0 ; if (s.indexOf( "IV" )!=- 1 ){sum-= 2 ;} if (s.indexOf( "IX" )!=- 1 ){sum-= 2 ;} if (s.indexOf( "XL" )!=- 1 ){sum-= 20 ;} if (s.indexOf( "XC" )!=- 1 ){sum-= 20 ;} if (s.indexOf( "CD" )!=- 1 ){sum-= 200 ;} if (s.indexOf( "CM" )!=- 1 ){sum-= 200 ;} char c[]=s.toCharArray(); int count= 0 ; for (;count<=s.length()- 1 ;count++){ if (c[count]== 'M' ) sum+= 1000 ; if (c[count]== 'D' ) sum+= 500 ; if (c[count]== 'C' ) sum+= 100 ; if (c[count]== 'L' ) sum+= 50 ; if (c[count]== 'X' ) sum+= 10 ; if (c[count]== 'V' ) sum+= 5 ; if (c[count]== 'I' ) sum+= 1 ; } return sum; } |
Java:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 | public int romanToInt(String s) { int nums[]= new int [s.length()]; for ( int i= 0 ;i<s.length();i++){ switch (s.charAt(i)){ case 'M' : nums[i]= 1000 ; break ; case 'D' : nums[i]= 500 ; break ; case 'C' : nums[i]= 100 ; break ; case 'L' : nums[i]= 50 ; break ; case 'X' : nums[i]= 10 ; break ; case 'V' : nums[i]= 5 ; break ; case 'I' : nums[i]= 1 ; break ; } } int sum= 0 ; for ( int i= 0 ;i<nums.length- 1 ;i++){ if (nums[i]<nums[i+ 1 ]) sum-=nums[i]; else sum+=nums[i]; } return sum+nums[nums.length- 1 ]; } |
Python:
1 2 3 4 5 6 7 8 9 10 11 12 | class Solution: # @param {string} s # @return {integer} def romanToInt( self , s): roman = { 'M' : 1000 , 'D' : 500 , 'C' : 100 , 'L' : 50 , 'X' : 10 , 'V' : 5 , 'I' : 1 } z = 0 for i in range ( 0 , len (s) - 1 ): if roman[s[i]] < roman[s[i + 1 ]]: z - = roman[s[i]] else : z + = roman[s[i]] return z + roman[s[ - 1 ]] |
Python:
1 2 3 4 5 6 7 8 9 10 11 | class Solution: # @return an integer def romanToInt( self , s): numeral_map = { "I" : 1 , "V" : 5 , "X" : 10 , "L" : 50 , "C" : 100 , "D" : 500 , "M" : 1000 } decimal = 0 for i in xrange ( len (s)): if i > 0 and numeral_map[s[i]] > numeral_map[s[i - 1 ]]: decimal + = numeral_map[s[i]] - 2 * numeral_map[s[i - 1 ]] else : decimal + = numeral_map[s[i]] return decimal |
Python:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 | def romanToInt( self , s): """ :type s: str :rtype: int """ _dict = { 'I' : 1 , 'V' : 5 , 'X' : 10 , 'L' : 50 , 'C' : 100 , 'D' : 500 , 'M' : 1000 } prev = 0 sum = 0 for i in s[:: - 1 ]: curr = _dict[i] if prev > curr: sum - = curr else : sum + = curr prev = curr return sum |
C++:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 | class Solution { public : int romanToInt(string s) { unordered_map< char , int > numeral_map = {{ 'I' , 1}, { 'V' , 5}, { 'X' , 10}, { 'L' , 50}, { 'C' , 100}, { 'D' , 500}, { 'M' , 1000}}; int decimal = 0; for ( int i = 0; i < s.length(); ++i) { if (i > 0 && numeral_map[s[i]] > numeral_map[s[i - 1]]) { decimal += numeral_map[s[i]] - 2 * numeral_map[s[i - 1]]; } else { decimal += numeral_map[s[i]]; } } return decimal; } }; |
类似题目:
[LeetCode] 12. Integer to Roman 整数转为罗马数字
All LeetCode Questions List 题目汇总
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步