当前位置: 首页 > news >正文

leetCode算法—12. 整数转罗马数字

12. 整数转罗马数字

难度:中等 **

罗马数字包含以下七种字符: I, V, X, L,C,D 和 M。

字符 数值
I 1
V 5
X 10
L 50
C 100
D 500
M 1000
例如, 罗马数字 2 写做 II ,即为两个并列的 1。12 写做 XII ,即为 X + II 。 27 写做 XXVII, 即为 XX + V + II 。

通常情况下,罗马数字中小的数字在大的数字的右边。但也存在特例,例如 4 不写做 IIII,而是 IV。数字 1 在数字 5 的左边,所表示的数等于大数 5 减小数 1 得到的数值 4 。同样地,数字 9 表示为 IX。这个特殊的规则只适用于以下六种情况:

I 可以放在 V (5) 和 X (10) 的左边,来表示 4 和 9。
X 可以放在 L (50) 和 C (100) 的左边,来表示 40 和 90。
C 可以放在 D (500) 和 M (1000) 的左边,来表示 400 和 900。
给你一个整数,将其转为罗马数字。

  • 示例 1:
    输入: num = 3
    输出: “III”

  • 示例 2:
    输入: num = 4
    输出: “IV”

  • 示例 3:
    输入: num = 9
    输出: “IX”

  • 示例 4:
    输入: num = 58
    输出: “LVIII”
    解释: L = 50, V = 5, III = 3.

  • 示例 5:
    输入: num = 1994
    输出: “MCMXCIV”
    解释: M = 1000, CM = 900, XC = 90, IV = 4.

  • 提示:
    1 <= num <= 3999

解法:

const intToRoman = (num) => {const maps = [{ val: 1000, label: "M" }, { val: 900, label: "CM" }, { val: 500, label: "D" }, { val: 400, label: "CD" }, { val: 100, label: "C" }, { val: 90, label: "XC" }, { val: 50, label: "L" }, { val: 40, label: "XL" }, { val: 10, label: "X" }, { val: 9, label: "IX" }, { val: 5, label: "V" }, { val: 4, label: "IV" }, { val: 1, label: "I" }]let str = '';const len = maps.length;for (let i = 0; i < len; ++i) {const item = maps[i]while (num >= item.val) {num -= item.valstr += item.label}}return str
};

上一篇:leetCode算法—11. 盛最多水的容器
下一篇:leetCode算法—13. 罗马数字转整数

http://www.lryc.cn/news/265720.html

相关文章:

  • 使用OpenCV4实现工业缺陷检测的六种方法
  • Excel 获取当前行的行数
  • R语言【stringr】——str_detect 检测是否存在字符串的匹配项
  • 【SpringMVC】SpringMVC的请求与响应
  • Spring Boot3通过GraalVM生成exe执行文件
  • 【Amazon 实验②】使用缓存策略及源请求策略,用于控制边缘缓存的行为及回源行为
  • 达梦数据对比工具的部署与使用
  • TLC2543(12位A/D转换器)实现将输入的模拟电压显示到数码管上
  • npm的使用技巧
  • MySQL 5.6的新特性
  • 大模型重构云计算:AI原生或将改变格局
  • 一文讲清什么是TypeScript装饰器以及如何使用TypeScript装饰器
  • 恶意软件样本行为分析——Process Monitor和Wireshark
  • 【XR806开发板试用】通过http请求从心知天气网获取天气预报信息
  • NPM介绍与使用
  • servlet +thymeleaf渲染引擎
  • 10分钟了解nextTick,并实现简易版本的nextTick
  • oracle表空间对象迁移到其他表空间
  • <stdlib.h>头文件: C 语言常用标准库函数详解
  • Qt前端技术:3.QSS字体样式
  • 阿里面试官:面试了一个能力相当不错的候选人,但背调时,他前同事和领导都说他人品很差,纠结该不该要他?...
  • 如何设计树形结构
  • 限量25台,川崎亮相Ninja ZX-10RR冬季限量款
  • 【QT八股文】系列之篇章1 | QT的基础知识及事件/机制
  • SpringBoot 3 集成Hive 3
  • STL中优先队列的模拟实现与仿函数的介绍
  • LeetCode刷题--- 目标和
  • 【.NET Core】反射(Reflection)详解(二)
  • 【错误记录/js】保存octet-stream为文件后数据错乱
  • sql_lab之sqli中的post注入