深入探索力扣第12题:整数转罗马数字的算法之旅

news/2024/5/19 8:25:17/文章来源:https://blog.csdn.net/CCIEHL/article/details/137410166

 作者介绍:10年大厂数据\经营分析经验,现任大厂数据部门负责人。
会一些的技术:数据分析、算法、SQL、大数据相关、python

欢迎加入社区:码上找工作icon-default.png?t=N7T8http://t.csdnimg.cn/Q59WX作者专栏每日更新:

LeetCode解锁1000题: 打怪升级之旅icon-default.png?t=N7T8https://blog.csdn.net/cciehl/category_12625714.html
python数据分析可视化:企业实战案例icon-default.png?t=N7T8https://blog.csdn.net/cciehl/category_12615648.html
备注说明:方便大家阅读,统一使用python,带必要注释,公众号 数据分析螺丝钉 一起打怪升级

力扣(LeetCode)第12题“整数转罗马数字”提供了一个绝佳的学习机会,不仅让我们深入古罗马的数字系统,也锻炼了我们的编程技巧。一起看看其背后的逻辑。

罗马数字基础

罗马数字是一种古老的数字表示方法,广泛用于古罗马时期。不同于现代的十进制数字系统,罗马数字使用字母来表示不同的数值。以下是罗马数字的基本组成部分:

  • I(1)、V(5)、X(10)、L(50)、C(100)、D(500)、M(1000)

罗马数字的构造规则相对直观:通常情况下,罗马数字中小的数字在大的数字的右边。但也存在特例,例如 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。

问题描述

力扣第12题要求我们将给定的整数转换为罗马数字表示,该整数范围从1到3999。这个范围的限定是由罗马数字表示的上限所决定的。

示例 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. 准备映射表:首先,创建一个映射表,列出所有单一罗马数字及其值,以及特殊的减法规则组合(如IV表示4)。
  2. 逐步减少:从最大的数值和对应的罗马数字开始,尽可能多地从输入整数中减去该数值,每次减去时,将相应的罗马数字添加到结果字符串中。
  3. 重复直到完成:继续此过程,直到整数减少到0。

代码实现(Python)

def intToRoman(num: int) -> str:roman_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")
]roman_numeral = ""for value, symbol in roman_map:while num >= value:num -= valueroman_numeral += symbol
return roman_numeral

性能分析

对于该算法,其时间和空间复杂度都可以认为是O(1),因为罗马数字表示的整数有一个上限(3999),算法运行时间和所需空间并不随输入整数的大小而变化。

算法图解

动态GIF图

为了将上述绘图过程转换成动态GIF图片,我们需要在Python中采用稍微不同的方法。这通常涉及到在每个绘图步骤中保存图像,并最后使用这些图像来创建GIF。下面是一个如何实现这一过程的示例:

  1. 保存每一步的图像:在循环中,每执行一次操作(即每次从数字中减去一个罗马数字值),我们都将保存当前的图表状态作为一个图像文件。
  2. 创建GIF:使用这些图像文件创建GIF。我们可以使用像imageio这样的库来完成这个任务。

bb425c7b1df14e7385349539ee093b38.gif

代码实现(Python)

首先,确保你已经安装了imageio库。如果还没有安装,你可以通过运行pip install imageio来安装它。

接下来,让我们更新代码来实现这个过程:

import matplotlib.pyplot as plt
import imageio
import os# 定义罗马数字映射和待转换的数字
numerals = [(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')
]
num = 1994
original_num = num# 准备存放每一帧图像的目录
frames_dir = "frames_dir"
os.makedirs(frames_dir, exist_ok=True)filenames = []  # 存储每一帧图像文件名# 转换过程
result = ""  # 累积的罗马数字
for value, symbol in numerals:while num >= value:num -= valueresult += symbol# 绘图fig, ax = plt.subplots(figsize=(10, 6))ax.text(0.5, 0.7, f'Converting: {original_num} to Roman Numerals', ha='center', va='center', fontsize=14)ax.text(0.5, 0.5, f'- {symbol} ({value})', ha='center', va='center', fontsize=20, color='red')ax.text(0.5, 0.4, f'Remaining: {num}', ha='center', va='center', fontsize=14)ax.text(0.5, 0.6, f'Converted: {result}', ha='center', va='center', fontsize=14)ax.axis('off')# 保存图像filename = os.path.join(frames_dir, f'frame_{original_num - num}.png')plt.savefig(filename)plt.close()filenames.append(filename)# 生成GIF
gif_filename = 'roman_conversion.gif'
with imageio.get_writer(gif_filename, mode='I', duration=0.5) as writer:for filename in filenames:image = imageio.imread(filename)writer.append_data(image)# 清理临时文件
for filename in filenames:os.remove(filename)
os.rmdir(frames_dir)print(f"GIF saved as {gif_filename}")

执行步骤解析

  1. 初始化和映射定义:设置罗马数字映射和待转换的数字。
  2. 创建帧目录:为每一步生成的图像帧创建一个存放目录。
  3. 绘图和保存:对每个罗马数字减法操作,绘制并保存一帧图像。
  4. GIF生成:使用imageio读取所有帧图像并合成GIF。
  5. 清理:删除所有临时帧图像和目录。

结论

通过动态的GIF图示我们更好的掌握算法的运行步骤

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.luyixian.cn/news_show_1045563.aspx

如若内容造成侵权/违法违规/事实不符,请联系dt猫网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

业务逻辑漏洞(靶场) fiddler

目录 fiddler简介: 业务逻辑漏洞: fiddler下载 靶场: 实验一 ​编辑实验二(ps 更改实验url会变,fiddler没抓到东西看看代理改没改) 实验三 实验四 fiddler简介: 一款网络抓包工具&#…

ht1622不显示无反应问题解决

如果你正在写ht1622 驱动时,怎么看程序都没问题,抓取波形,示波器分析波形,如果都没有问题,那么很大可能是硬件问题,检测看看 ht1622 RD是不是接地了。 RD 低会进入读取模式,所以不用RD 请将RD悬…

雄安建博会:中矿雄安新区的总部开工建设

中矿落位雄安:助力国家战略与新区发展 雄安新区,作为中国未来发展的重要战略支点,正迎来一系列央企总部的疏解与建设。最近,中国矿产资源集团有限公司(简称“中矿”)在雄安新区的总部项目正式开工建设&…

Jettison 1.8.7直装版 外部磁盘辅助弹出

Jettison 是一款适用于 macOS 的实用工具,旨在简化外部驱动器的管理。它可以自动卸载和重新挂载外部驱动器,帮助您更方便地使用和保护您的存储设备。 软件下载:Jettison 1.8.7直装版下载 自动卸载和重新挂载:Jettison 可以在您离开…

yolo预标注的txt转换成labelme中segment的json

前言 在yolo预标注的时候,想把保存的txt转换成labelme中segment的json,于是写了下面的脚本。 1.引入库 完整代码: import os import json from tqdm import tqdmdef get_image_size(image_path):from PIL import Imagewith Image.open(ima…

Spring boot如何执行单元测试?

Spring Boot 提供了丰富的测试功能,主要由以下两个模块组成: spring-boot-test:提供测试核心功能。spring-boot-test-autoconfigure:提供对测试的自动配置。 Spring Boot 提供了一个 spring-boot-starter-test一站式启动器&…

unipush+个推实现消息推送

1.注册个推平台的帐号个推,专业的数据智能服务商-为垂直领域提供数据智能解决方案 2.应用列表中选择新增应用/服务 3.填写下应用信息4.创建好应用后在manifest.json中的sdkConfigs配置上写入appid、appkey、appsecret "sdkConfigs" : {"ad" :…

硬件学习件Cadence day16 做个笔记,BOM 位号这个参数输出的两种情况。

1. BOM 中位号有3种情况 1. 一种是位号生成时多行,每行是固定的位数。(如下图所示) 2. 一种是位号生成时只有一行,但是可以使用表格中自动换行功能,给他换行,但是这个位号本质上只有一行,只是因…

基于深度学习的乳腺癌智能检测分割与诊断系统【python源码+Pyqt5界面+数据集+训练代码】深度学习实战、目标分割、人工智能

《博主简介》 小伙伴们好,我是阿旭。专注于人工智能、AIGC、python、计算机视觉相关分享研究。 ✌更多学习资源,可关注公-仲-hao:【阿旭算法与机器学习】,共同学习交流~ 👍感谢小伙伴们点赞、关注! 《------往期经典推…

虚拟网络设备的真正使命:实现有控制的通信

在数字化时代📲,网络安全🔒成为了企业和个人防御体系中不可或缺的一部分。随着网络攻击的日益复杂和频繁🔥,传统的物理网络安全措施已经无法满足快速发展的需求。虚拟网络设备🖧,作为网络架构中…

一起学习python——基础篇(5)

今天讲一下python的数据类型。 数据类型主要分为文本类型、数值类型、序列类型、映射类型、集合类型、布尔类型、二进制类型六大类型。 文本类型:str 数值类型: int, float, complex 序列类型: list, tuple, range 映射类型:…

【数据结构与算法】搜索算法(深度优先搜索 DFS和广度优先搜索 BFS)以及典型算法例题

目录 搜索算法(深度优先搜索DFS和广度优先搜索BFS)以及典型算法例题深度优先搜索 (Depth First Search 简称 DFS)DFS 的设计步骤深度优先搜索(DFS)算法例题例题一:N皇后问题例题二:路…

SQL注入sqli_labs靶场第五、六题

第五题 根据报错信息,判断为单引号注入 没有发现回显点 方法:布尔盲注(太耗时,不推荐使用) 1)猜解数据库名字:(所有ASCII码值范围:0~127) ?id1 and length…

成功解决> 错误: 无效的源发行版:17

运行项目的时候出现下面的报错: Execution failed for task ‘:device_info_plus:compileDebugJavaWithJavac’. 错误: 无效的源发行版:17 原因:没有设置好自己项目的JDK版本 解决:1.检查自己项目的JDK版本 将自己的项目改为JDK 1…

MySQL高级(索引分类-聚集索引-二级索引)

目录 1、主键索引、唯一索引、常规索引、全文索引 2、 聚集索引、二级索引 3、回表查询 4、通过id查询和通过name查询那个执行效率高? 5、 InnoDB主键索引的 B tree 高度为多高呢? 1、主键索引、唯一索引、常规索引、全文索引 在MySQL数据库&#xff0c…

C++的stack和queue类(一):适配器模式、双端队列与优先级队列

目录 基本概念 stack的使用 queue的使用 适配器模式 stack.h test.cpp 双端队列-deque 仿函数 优先队列 priority_queue的使用 queue.h文件 stack.h文件 test.cpp文件 日期类的比较 商品的比较 结论 基本概念 1、stack和queue不是容器而是容器适配器&…

性能优化原则

相关链接:【运行环境】加载资源的形式 性能优化 1 性能优化原则 多使用内存、缓存或其他方法 减少CPU计算量,减少网络加载耗时 (适用于所有编程的性能优化----空间换时间) 2 从何入手 性能优化-让加载更快 减少资源体积&#x…

每日一题 — 最大连续 1 的个数III

解法一:暴力枚举 先定义left和right双指针,left先固定在起始位置,遍历right当值等于1的时候,直接跳过,等于0的时候,zero计数器加一当zero等于k的时候,就开始记录此时最大长度是多少然后left加一…

深度剖析:网络安全中的红蓝对抗策略

红蓝对抗 红蓝对抗服务方案 在蓝队服务中,作为攻击方将开展对目标资产的模拟入侵,寻找攻击路径,发现安全漏洞和隐患。除获取目标系统的关键信息(包括但不限于资产信息、重要业务数据、代码或管理员账号等)外&#x…

Python | 超前滞后分析

Nino SST Indices (Nino 12, 3, 3.4, 4; ONI and TNI) 有几个指标用于监测热带太平洋,所有这些指标都是基于海表温度(SST)异常在一个给定的区域的平均值。通常,异常是相对于30年的周期来计算的。厄尔尼诺3.4指数(Nio 3.4 index)和海洋厄尔尼诺指数(Ocea…