###### tags: `leetcode` `easy` `Hash Table` `Math` `String`
# [13. Roman to Integer](https://leetcode.com/problems/roman-to-integer/)
## Description
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, `2` is written as `II` in Roman numeral, just two ones added together. `12` is written as `XII`, which is simply `X + II`. The number `27` 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.
## Examples
### Example 1:
Input: s = "III"
Output: 3
Explanation: III = 3.
### Example 2:
Input: s = "LVIII"
Output: 58
Explanation: L = 50, V= 5, III = 3.
### Example 3:
Input: s = "MCMXCIV"
Output: 1994
Explanation: M = 1000, CM = 900, XC = 90 and IV = 4.
## Constraints:
- $1 \leq s.length \leq 15$
- `s` contains only the characters` ('I', 'V', 'X', 'L', 'C', 'D', 'M')`.
- It is **guaranteed** that `s` is a valid roman numeral in the range `[1, 3999]`.
## Code
```c=
int romanToInt(char* s) {
int ans = 0, length = strlen(s);
int* strArray = calloc(length, sizeof(int));
for (int i = 0; i < length; i++) {
switch (s[i]) {
case 'I':
strArray[i] = 1;
break;
case 'V':
strArray[i] = 5;
break;
case 'X':
strArray[i] = 10;
break;
case 'L':
strArray[i] = 50;
break;
case 'C':
strArray[i] = 100;
break;
case 'D':
strArray[i] = 500;
break;
case 'M':
strArray[i] = 1000;
break;
default:
printf("Error input!\n");
break;
}
}
for (int i = 0; i < length; i++) {
if (i != length - 1 && strArray[i] < strArray[i + 1]) {
ans += strArray[i + 1] - strArray[i++];
} else {
ans += strArray[i];
}
}
return ans;
}
```
## Complexity
|Space |Time |
|- |- |
|$O(N)$|$O(N)$|
## Result
- Runtime: 15 ms, faster than 37.29%
- Memory Usage: 5.8 MB, less than 53.70%