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
}

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

全部评论

相关推荐

07-09 20:50
门头沟学院 Java
码农索隆:1.教育背景和荣誉证书合二为一。 2.获奖项目理一遍,你做了什么,对你求职的岗位有什么帮助,没有就删掉。 3.技能特长和教育背景交换位置。 4.技能特长写的太差,上网上找简历参考。都不用问你别的,一个redis就能把你问住,写写你具体会redis哪些方面的知识。
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务