Ai
1 Star 2 Fork 5

LilithSangreal/LeetCode-Solutions

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
克隆/下载
roman-to-integer.cpp 1.26 KB
一键复制 编辑 原始数据 按行查看 历史
kamyu 提交于 2018-11-03 19:08 +08:00 . Update roman-to-integer.cpp
// Time: O(n)
// Space: O(1)
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;
}
};
// Time: O(n)
// Space: O(1)
class Solution2 {
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}};
return accumulate(s.crbegin(), s.crend(), 0,
[&numeral_map](int sum , char c) {
return sum += ((numeral_map[c] * 5 <= sum) ?
-numeral_map[c] : numeral_map[c]);
});
}
};
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
1
https://gitee.com/LilithSangreal/LeetCode-Solutions.git
git@gitee.com:LilithSangreal/LeetCode-Solutions.git
LilithSangreal
LeetCode-Solutions
LeetCode-Solutions
master

搜索帮助