12. 整数转罗马数字(LeetCode)

简介: 罗马数字包含以下七种字符: I, V, X, L,C,D 和 M。例如, 罗马数字 2 写做 II ,即为两个并列的 1。12 写做 XII ,即为 X + II 。 27 写做 XXVII, 即为 XX + V + II 。通常情况下,罗马数字中小的数字在大的数字的右边。但也存在特例,例如 4 不写做 IIII,而是 IV。数字 1 在数字 5 的左边,所表示的数等于大数 5 减小数 1 得到的数值 4 。同样地,数字 9 表示为 IX。

罗马数字包含以下七种字符: 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:

1. 输入: num = 3
2. 输出: "III"

示例 2:

1. 输入: num = 4
2. 输出: "IV"

示例 3:

1. 输入: num = 9
2. 输出: "IX"

示例 4:

1. 输入: num = 58
2. 输出: "LVIII"

示例 5:

1. 输入: num = 1994
2. 输出: "MCMXCIV"
3. 解释: M = 1000, CM = 900, XC = 90, IV = 4.

提示:

1 <= num <= 3999

通过次数270,511提交次数407,794

请问您在哪类招聘中遇到此题?

来源:力扣(LeetCode

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

PS:

多尝试几个数字,就会发现我们可以把数字拆成(1000,900,500,400,100,90,50,40,10,9,5,4,1)

而其对应的罗马数字如下:("M","CM","D","CD","C","XC","L","XL","X","IX","V","IV","I")

代码如下:

class Solution {
public:
    string intToRoman(int num) {
        int number[13]={1000,900,500,400,100,90,50,40,10,9,5,4,1};
        string str[13]={"M","CM","D","CD","C","XC","L","XL","X","IX","V","IV","I"};
        string input;
        for(int i=0;i<13;i++){
            while(num>=number[i]){
                num-=number[i];
                input+=str[i];
            }
            if(num==0)
            break;
        }
        return
    }
};


相关文章
|
消息中间件 存储 数据采集
iLogtail社区版使用入门 - 主机环境采集业务日志到SLS
本文将会详细介绍如何使用社区版iLogtail,并结合SLS云服务快速构建出一套高可用、高性能的日志采集分析系统
2057 0
|
Java
规则引擎选型及应用
规则引擎具体执行可以分为接受数据输入,解释业务规则,根据业务规则做出业务决策几个过程。 使用规则引擎可以把复杂、冗余的业务规则同整个支撑系统分离开,做到架构的可复用移植。
24466 0
|
Ubuntu 关系型数据库 MySQL
如何在 Ubuntu 20.04 上安装 MySQL
MySQL是最流行的开源关系数据库管理系统。它速度快,容易使用,容易扩展,并且流行的LAMP和LEMP的一部分。 这篇指南讲解了如何在 Ubuntu 20.04上安装和保护 MySQL。 一、前提条件 确保你以 sudo 用户身份登录 二、在 Ubuntu 上安装 MySQL 在写作这篇文章的时候,Ubuntu 源仓库中最新的 MySQL 版本号是 MySQL 8.0。
57997 4
如何在 Ubuntu 20.04 上安装 MySQL
|
监控 网络协议 安全
DNS服务器故障不容小觑,从应急视角谈DNS架构
DNS服务器故障不容小觑,从应急视角谈DNS架构
290 4
|
Linux Docker Windows
Docker配置https证书案例
本文介绍了如何为Docker的Harbor服务配置HTTPS证书,包括安装Docker和Harbor、修改配置文件以使用证书、生成自签名证书、配置证书以及验证配置的步骤。
1100 3
Docker配置https证书案例
|
存储 算法 搜索推荐
Python进阶必备:字典树Trie与后缀树Suffix Array,效率提升的神器!
在Python编程中,掌握高效的数据结构对于提升程序性能至关重要。本文将深入探讨两种强大的字符串处理数据结构——字典树(Trie)与后缀数组(Suffix Array)。字典树,又称前缀树,适用于自动补全和拼写检查等功能。例如,在文本编辑器中实现自动补全时,字典树能够即时提供单词补全选项。后缀数组则用于存储字符串的所有后缀并按字典序排序,结合最长公共前缀(LCP)数组,可以高效解决许多字符串问题,如查找最长重复子串等。通过实际案例,我们将展示这两种数据结构的强大功能,帮助你在Python编程中更进一步。
269 2
|
JavaScript Java 测试技术
基于SpringBoot+Vue+uniapp微信小程序的体育馆使用预约平台的详细设计和实现
基于SpringBoot+Vue+uniapp微信小程序的体育馆使用预约平台的详细设计和实现
203 2
基于SpringBoot+Vue+uniapp微信小程序的体育馆使用预约平台的详细设计和实现
|
机器学习/深度学习 人工智能 自然语言处理
【人工智能】TensorFlow简介,应用场景,使用方法以及项目实践及案例分析,附带源代码
TensorFlow是由Google Brain团队开发的开源机器学习库,广泛用于各种复杂的数学计算,特别是涉及深度学习的计算。它提供了丰富的工具和资源,用于构建和训练机器学习模型。TensorFlow的核心是计算图(Computation Graph),这是一种用于表示计算流程的图结构,由节点(代表操作)和边(代表数据流)组成。
623 0
|
开发者 Python
入门实战丨Python小游戏经典案例
入门实战丨Python小游戏经典案例
303 4
|
JSON 安全 Java
Spring Security 与 JWT、OAuth 2.0 整合详解:构建安全可靠的认证与授权机制
Spring Security 与 JWT、OAuth 2.0 整合详解:构建安全可靠的认证与授权机制
1609 0