|
|
/*
|
|
|
* @lc app=leetcode id=13 lang=cpp
|
|
|
*
|
|
|
* [13] Roman to Integer
|
|
|
*
|
|
|
* https://leetcode.com/problems/roman-to-integer/description/
|
|
|
*
|
|
|
* algorithms
|
|
|
* Easy (53.27%)
|
|
|
* Likes: 1444
|
|
|
* Dislikes: 2872
|
|
|
* Total Accepted: 488.4K
|
|
|
* Total Submissions: 916.4K
|
|
|
* Testcase Example: '"III"'
|
|
|
*
|
|
|
* 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 before V (5) and X (10) to make 4 and 9.
|
|
|
* X can be placed before L (50) and C (100) to make 40 and 90.
|
|
|
* C can be placed before D (500) and M (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.
|
|
|
*
|
|
|
*/
|
|
|
#include <bits/stdc++.h>
|
|
|
using namespace std;
|
|
|
class Solution
|
|
|
{
|
|
|
public:
|
|
|
int romanToInt(const string &s)
|
|
|
{
|
|
|
auto str = s.c_str();
|
|
|
int res = 0, len = s.size();
|
|
|
for (int i = 0; i < len; i++)
|
|
|
switch (str[i])
|
|
|
{
|
|
|
case 'I':
|
|
|
if (str[i + 1] == 'V')
|
|
|
res += 4, i++;
|
|
|
else if (str[i + 1] == 'X')
|
|
|
res += 9, i++;
|
|
|
else
|
|
|
res += 1;
|
|
|
break;
|
|
|
case 'X':
|
|
|
if (str[i + 1] == 'L')
|
|
|
res += 40, i++;
|
|
|
else if (str[i + 1] == 'C')
|
|
|
res += 90, i++;
|
|
|
else
|
|
|
res += 10;
|
|
|
break;
|
|
|
case 'C':
|
|
|
if (str[i + 1] == 'D')
|
|
|
res += 400, i++;
|
|
|
else if (str[i + 1] == 'M')
|
|
|
res += 900, i++;
|
|
|
else
|
|
|
res += 100;
|
|
|
break;
|
|
|
case 'V':
|
|
|
res += 5;
|
|
|
break;
|
|
|
case 'L':
|
|
|
res += 50;
|
|
|
break;
|
|
|
case 'D':
|
|
|
res += 500;
|
|
|
break;
|
|
|
case 'M':
|
|
|
res += 1000;
|
|
|
break;
|
|
|
}
|
|
|
return res;
|
|
|
}
|
|
|
};
|