leetcode/src/s0013_roman_to_integer.cpp

28 lines
566 B
C++

#include "s0013_roman_to_integer.hpp"
int S0013::romanToInt(string s) {
unordered_map<string, int> map;
map["I"] = 1;
map["V"] = 5;
map["X"] = 10;
map["L"] = 50;
map["C"] = 100;
map["D"] = 500;
map["M"] = 1000;
int val{0};
int len = s.length();
for (int i{0}; i < len; i++) {
if (i == len - 1) {
val += map.at(s.substr(i, 1));
} else {
if (map.at(s.substr(i, 1)) < map.at(s.substr(i + 1, 1))) {
val -= map.at(s.substr(i, 1));
} else {
val += map.at(s.substr(i, 1));
}
}
}
return val;
}