js实现力扣第13题(罗马数字转整数)

原题链接:https://leetcode.cn/problems/roman-to-integer

1.解题思路

罗马数字转整数的核心逻辑是:

  1. 建立映射表:将罗马字符和对应的整数值一一对应,方便快速查询。
  2. 遍历判断规则
    • 正常情况:小数字在大数字右侧,直接累加(如 VI = 5+1 = 6)。
    • 特殊情况:小数字在大数字左侧,用大数字减小数字(如 IV = 5-1 = 4)。
  1. 简化判断逻辑:遍历每个字符时,只需比较当前字符值和下一个字符值:
    • 如果当前值 < 下一个值 → 减去当前值(对应特殊情况)。
    • 如果当前值 ≥ 下一个值 → 加上当前值(对应正常情况)。
    • 最后一个字符直接累加(无下一个字符)。

2.代码实现

javascript 复制代码
/**
 * @param {string} s
 * @return {number}
 */
var romanToInt = function(s) {
  const map = new Map()
  map.set('I',1)
  map.set('V',5)
  map.set('X',10)
  map.set('L',50)
  map.set('C',100)
  map.set('D',500)
  map.set('M',1000)
  let sum = 0 
  for(let i = 0;i<s.length;i++){
    if(map.get(s[i])<map.get(s[i+1])){
      sum -= map.get(s[i])
    }else {
      sum += map.get(s[i])
    }
  }
  return sum
};

3.解题过程拆解(以 MCMXCIV 为例)

我们以示例 5 的 MCMXCIV(对应 1994)为例,一步步拆解执行过程:

|----------|----------|----------------|-----------|-------------|-----------------|---------------|
| 索引 i | 当前字符 | currentVal | 下一个字符 | nextVal | 判断逻辑 | result 变化 |
| 0 | M | 1000 | C | 100 | 1000 ≥ 100 → + | 0+1000=1000 |
| 1 | C | 100 | M | 1000 | 100 < 1000 → - | 1000-100=900 |
| 2 | M | 1000 | X | 10 | 1000 ≥ 10 → + | 900+1000=1900 |
| 3 | X | 10 | C | 100 | 10 < 100 → - | 1900-10=1890 |
| 4 | C | 100 | I | 1 | 100 ≥ 1 → + | 1890+100=1990 |
| 5 | I | 1 | V | 5 | 1 < 5 → - | 1990-1=1989 |
| 6 | V | 5 | 无 | 0 | 5 ≥ 0 → + | 1989+5=1994 |

4.复杂度分析

  1. 时间复杂度:O(n)
    • n 是罗马数字字符串的长度,只需遍历字符串一次,每个字符的查询和计算都是 O (1) 操作。
    • 无论字符串多长,遍历次数和字符串长度成正比,因此时间复杂度为线性。
  1. 空间复杂度:O(1)
    • 映射表 map 存储的是固定的 7 组键值对,不随输入字符串长度变化。
    • 仅使用了常数级别的额外空间,因此空间复杂度为常数级。
相关推荐
u01092727111 小时前
C++中的策略模式变体
开发语言·c++·算法
2501_9418372611 小时前
停车场车辆检测与识别系统-YOLOv26算法改进与应用分析
算法·yolo
雨季66612 小时前
构建 OpenHarmony 简易文字行数统计器:用字符串分割实现纯文本结构感知
开发语言·前端·javascript·flutter·ui·dart
雨季66612 小时前
Flutter 三端应用实战:OpenHarmony 简易倒序文本查看器开发指南
开发语言·javascript·flutter·ui
小北方城市网12 小时前
Redis 分布式锁高可用实现:从原理到生产级落地
java·前端·javascript·spring boot·redis·分布式·wpf
2401_8920005212 小时前
Flutter for OpenHarmony 猫咪管家App实战 - 添加支出实现
前端·javascript·flutter
天马379812 小时前
Canvas 倾斜矩形绘制波浪效果
开发语言·前端·javascript
六义义13 小时前
java基础十二
java·数据结构·算法
四维碎片13 小时前
QSettings + INI 笔记
笔记·qt·算法
天天向上102413 小时前
vue3 实现el-table 部分行不让勾选
前端·javascript·vue.js