LeetCode#13罗马数字转整数

题目描述

/**
 * @param {string} s
 * @return {number}
 */
var romanToInt = function(s) {
  // 1创建罗马-数字对应的数据结构 Hash表
  let result = 0
  let obj = {
    'I': 1,
    'V': 5,
    'X': 10,
    'L': 50,
    'C': 100,
    'D': 500,
    'M': 1000,
  }
  // 2循环遍历Input
  for (let i = 0; i < s.length; i++) {
    let front = s[i], back = s[i + 1]
    // 3判断
    if (obj[front] < obj[back])
      result -= obj[front]
    else
      result += obj[front]
  }
  // 4输出结果
  return result
}

使用哈希表和双指针解答。

欢迎大家来我的 [Gitee仓库](https://gitee.com/jiffyzhang)参观。 同时欢迎关注我的同名公众号:就这样写(keepStarve),未来很大可能会活跃在此地。
原文地址:https://www.cnblogs.com/zhang-bobo/p/13737313.html