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

Leetcode 整数转罗马数字

在这里插入图片描述

这段代码的算法思想是基于罗马数字的减法规则,将整数转换为罗马数字的字符串表示。下面是详细的解释:

算法步骤:

  1. 定义数值和符号对应关系:代码中定义了两个数组:valuessymbolsvalues 数组包含了罗马数字的数值,按从大到小的顺序排列;symbols 数组包含了与这些数值对应的罗马数字符号。比如,1000 对应 “M”,900 对应 “CM”,依此类推。

    int[] values = {1000, 900, 500, 400, 100, 90, 50, 40, 10, 9, 5, 4, 1};
    String[] symbols = {"M", "CM", "D", "CD", "C", "XC", "L", "XL", "X", "IX", "V", "IV", "I"};
    
  2. 初始化结果:使用 StringBuilder 对象 roman 来存储结果字符串,最终得到罗马数字的表示形式。

    StringBuilder roman = new StringBuilder();
    
  3. 循环匹配数值:使用一个 for 循环遍历 values 数组中的每个数值。对于每个数值 values[i],我们通过 while 循环检查当前的数字 num 是否大于等于 values[i]

    • 如果 num >= values[i],说明 num 中包含了 values[i] 所代表的罗马数字部分。
    • while 循环中,我们将 values[i]num 中减去,并将对应的罗马数字符号 symbols[i] 添加到 roman 中。
    • 这样做的目的是确保将大的数值优先匹配完毕,从而符合罗马数字的书写规则。
    for (int i = 0; i < values.length && num > 0; i++) {while (num >= values[i]) {num -= values[i];roman.append(symbols[i]);}
    }
    
  4. 结束条件:当 num 被减到零时,说明所有的数值都已经转换为罗马数字表示。此时,我们退出循环。

  5. 返回结果:将 StringBuilder 对象 roman 转换为字符串并返回,得到最终的罗马数字表示。

    return roman.toString();
    

算法思想总结:

该算法采用贪心策略,即每次从最大的数值开始匹配并减去,直到 num
为零。因为罗马数字规则要求从高位到低位的排列,所以按照从大到小的顺序进行匹配和减法操作可以保证最终结果符合罗马数字的标准格式。

同时,这种方法避免了复杂的判断逻辑,是一种高效的解决方案。

通过这种方式,我们可以将整数逐步转换为符合规则的罗马数字字符串。

Java 实现

class Solution {public String intToRoman(int num) {int[] values = {1000, 900, 500, 400, 100, 90, 50, 40, 10, 9, 5, 4, 1};String[] symbols = {"M", "CM", "D", "CD", "C", "XC", "L", "XL", "X", "IX", "V", "IV", "I"};StringBuilder roman = new StringBuilder();for(int i = 0; i < values.length && num > 0; i++) {while(num >= values[i]) {num -= values[i];roman.append(symbols[i]);}}return roman.toString();}
}

http://www.mrgr.cn/news/74804.html

相关文章:

  • Qt 正则表达式提取文件中的 USB 设备 ID
  • java项目-jenkins任务的创建和执行
  • 【api】java和python联动
  • idea 删除本地分支后,弹窗 delete tracked brank
  • conda 启动时添加执行脚本
  • 【NLP优化】Ubuntu 20.04 下 源码安装 CasADi + Ipopt / acados
  • error: unrecognized arguments: --port
  • 新能源汽车关键技术技能大赛理论知识竞赛题库
  • 一文简单了解Android中的input流程
  • ospf排错学习
  • 分清数据链路层、网络层、传输层的区别,以及这些层面的代表协议
  • 计算机文件msvcp100.dll丢失原因以及5种解决方法详解分享
  • macOS系统下使用SQLark连接达梦数据库
  • 探索大型语言模型(LLMs)能否在不泄露私人信息的情况下联合其他大型语言模型共同解决问题
  • 从前端react动画引发到计算机底层的思考
  • 【图像压缩感知】论文阅读:Self-supervised Scalable Deep Compressed Sensing
  • Process finished with exit code 137 (interrupted by signal 9: SIGKILL)
  • 【Bluedroid】A2dp初始化流程源码分析
  • 重学 Android 自定义 View 系列(六):环形进度条
  • 达梦数据库迁移j脚本
  • C++ STL -- 模版
  • Python 数据可视化pilot
  • 支付宝碰一下系统怎么搭建?方法非常简单!
  • 全球经济风雨飘摇,OJK能带领印尼金融创新走多远?
  • Tcp/Ip协议,tcp相关文章,网络编程,通信协议文章汇总
  • 中国联通将军澳数据中心:全栈解决方案,助力企业创新