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

LeetCode12_整数转罗马数字

LeetCode12_整数转罗马数字

  • 标签:#哈希表 #数字 #字符串
    • Ⅰ. 题目
    • Ⅱ. 示例
  • 0. 个人方法:模拟
  • 官方题解二:硬编码数字

标签:#哈希表 #数字 #字符串

Ⅰ. 题目

  • 七个不同的符号代表罗马数字,其值如下:
符号
I1
V5
X10
L50
C100
D500
M1000
  • 罗马数字是通过添加从最高到最低的小数位值的转换而形成的。将小数位值转换为罗马数字有以下规则:

  • 如果该值不是以 4 或 9 开头,请选择可以从输入中减去的最大值的符号,将该符号附加到结果,减去其值,然后将其余部分转换为罗马数字。

  • 如果该值以 4 或 9 开头,使用 减法形式,表示从以下符号中减去一个符号,例如 4 是 5 (V) 减 1 (I): IV ,9 是 10 (X) 减 1 (I):IX。仅使用以下减法形式:4 (IV),9 (IX),40 (XL),90 (XC),400 (CD) 和 900 (CM)。

  • 只有 10 的次方(I, X, C, M)最多可以连续附加 3 次以代表 10 的倍数。你不能多次附加 5 (V),50 (L) 或 500 (D)。如果需要将符号附加4次,请使用 减法形式。

  • 给定一个整数,将其转换为罗马数字。

Ⅱ. 示例

· 示例 1:
输入:num = 3749
输出: “MMMDCCXLIX”
解释:
3000 = MMM 由于 1000 (M) + 1000 (M) + 1000 (M)
700 = DCC 由于 500 (D) + 100 © + 100 ©
40 = XL 由于 50 (L) 减 10 (X)
9 = IX 由于 10 (X) 减 1 (I)
注意:49 不是 50 (L) 减 1 (I) 因为转换是基于小数位

· 示例 2:
输入:num = 58
输出:“LVIII”
解释:
50 = L
8 = VIII

· 示例 3:
输入:num = 1994
输出:“MCMXCIV”
解释:
1000 = M
900 = CM
90 = XC
4 = IV

0. 个人方法:模拟

class Solution {
public:string intToRoman(int num) {std::vector<std::pair<int, std::string>> renoma_map = {{1000, "M"}, {900, "CM"}, {500, "D"}, {400, "CD"}, {100, "C"},{90, "XC"}, {50, "L"}, {40, "XL"}, {10, "X"}, {9, "IX"}, {5, "V"}, {4, "IV"}, {1, "I"}};std::string roma = "";for (const auto& pair : renoma_map){while (num >= pair.first){roma += pair.second;  // 添加符号num -= pair.first;    // 减去对应的值}}return roma;}
};

(官方题解一,即上述模拟,因此跳过)

官方题解二:硬编码数字

在这里插入图片描述
在这里插入图片描述

  • 利用模运算和除法运算,我们可以得到 num 每个位上的数字:
thousands_digit = num / 1000
hundreds_digit = (num % 1000) / 100
tens_digit = (num % 100) / 10
ones_digit = num % 10
  • 最后,根据 num 每个位上的数字,在硬编码表中查找对应的罗马字符,并将结果拼接在一起,即为 num 对应的罗马数字。
const string thousands[] = {"", "M", "MM", "MMM"};
const string hundreds[]  = {"", "C", "CC", "CCC", "CD", "D", "DC", "DCC", "DCCC", "CM"};
const string tens[]      = {"", "X", "XX", "XXX", "XL", "L", "LX", "LXX", "LXXX", "XC"};
const string ones[]      = {"", "I", "II", "III", "IV", "V", "VI", "VII", "VIII", "IX"};class Solution {
public:string intToRoman(int num) {return thousands[num / 1000] + hundreds[num % 1000 / 100] + tens[num % 100 / 10] + ones[num % 10];}
};
  • 复杂度分析

  • 时间复杂度:O(1)。计算量与输入数字的大小无关。

  • 空间复杂度:O(1)。

相关文章:

  • 人机鉴权和机机鉴权
  • 【算法应用】基于灰狼算法求解DV-Hop定位问题
  • 面试:结构体默认是对齐的嘛?如何禁止对齐?
  • 【每日随笔】文化属性 ① ( 天机 | 强势文化与弱势文化 | 文化属性的形成与改变 | 强势文化 具备的特点 )
  • 利用脚本搭建私有云平台,部署云平台,发布云主机并实现互连和远程连接
  • AI发展史
  • MySQL索引优化与实战 - Java架构师面试解析
  • springboot logback 默认加载配置文件顺序
  • 构建事件驱动的云原生后端系统 —— 从设计到实践
  • ecovadis认证评估标准?ecovadis审核目的?
  • 教育培训平台源码选型避坑指南:如何避免二次开发的高成本?
  • JavaScript基础(七)之web APIs
  • 基于Qt5的蓝牙打印开发实战:从扫描到小票打印的全流程
  • 20.压敏电阻的特性与使用注意事项
  • 【Git】初始Git及入门命令行
  • 一周学会Pandas2 Python数据处理与分析-Pandas2统计计算操作
  • 航顺 芯片 开发记录 (一) 2025年4月27日19:23:32
  • Java位运算符大全
  • 学生公寓限电模块控制柜是如何实现智能限电功能?
  • Git 全面解析:从核心概念到生态应用
  • 五一假期上海铁路预计发送446万人次,同比增长8.4%
  • 日月谭天丨赖清德强推“脱中入北”是把台湾带向死路
  • 全国电影工作会:聚焦扩大电影国际交流合作,提升全球影响力
  • 五矿地产:今年要确保债务“不爆雷”、交付“不烂尾”
  • 30天内三访中国,宝马董事长:没有一家公司可以在全球价值链外独立运行
  • 政治局会议:持续稳定和活跃资本市场