13_罗马数字转整数

news/2025/7/9 11:31:08/文章来源:https://www.cnblogs.com/zeta186012/p/18405308

13_罗马数字转整数

【问题描述】

罗马数字包含以下七种字符: IVXLCDM

字符          数值
I             1
V             5
X             10
L             50
C             100
D             500
M             1000

例如, 罗马数字 2 写做 II ,即为两个并列的 1 。12 写做 XII ,即为 X + II27 写做 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。

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

示例一:
输入: s = "III"
输出: 3

【算法设计思想】

本题的解决关键是如何应用映射关系,例如如何解处理字符"I"所对应的1这个问题。在C++中,我们可以使用unordered_map这个容器,在Java中我们可以使用HashMap这种容器,在Python中我们使用字典,在C语言中,我们可以利用不同字母的ASCII值来构建一个"哈希表",然后我们遍历这个字符串即可。同时在遍历的时候,我们需要注意当前字符和下一个字符所对应的数字的大小关系

【算法描述】

C++:

class Solution {
private:unordered_map<char, int> symbolValues = {{'I', 1},{'V', 5},{'X', 10},{'L', 50},{'C', 100},{'D', 500},{'M', 1000},};public:int romanToInt(string s) {int ans = 0;int n = s.length();for (int i = 0; i < n; ++i) {int value = symbolValues[s[i]];if (i < n - 1 && value < symbolValues[s[i + 1]]) {ans -= value;} else {ans += value;}}return ans;}
};

Java:

class Solution {Map<Character, Integer> symbolValues = new HashMap<Character, Integer>() {{put('I', 1);put('V', 5);put('X', 10);put('L', 50);put('C', 100);put('D', 500);put('M', 1000);}};public int romanToInt(String s) {int ans = 0;int n = s.length();for (int i = 0; i < n; ++i) {int value = symbolValues.get(s.charAt(i));if (i < n - 1 && value < symbolValues.get(s.charAt(i + 1))) {ans -= value;} else {ans += value;}}return ans;}
}

Python:

class Solution:SYMBOL_VALUES = {'I': 1,'V': 5,'X': 10,'L': 50,'C': 100,'D': 500,'M': 1000,}def romanToInt(self, s: str) -> int:ans = 0n = len(s)for i, ch in enumerate(s):value = Solution.SYMBOL_VALUES[ch]if i < n - 1 and value < Solution.SYMBOL_VALUES[s[i + 1]]:ans -= valueelse:ans += valuereturn ans

C:

int romanToInt(char* s) {int symbolValues[26];symbolValues['I' - 'A'] = 1;symbolValues['V' - 'A'] = 5;symbolValues['X' - 'A'] = 10;symbolValues['L' - 'A'] = 50;symbolValues['C' - 'A'] = 100;symbolValues['D' - 'A'] = 500;symbolValues['M' - 'A'] = 1000;int ans = 0;int n = strlen(s);for (int i = 0; i < n; ++i) {int value = symbolValues[s[i] - 'A'];if (i < n - 1 && value < symbolValues[s[i + 1] - 'A']) {ans -= value;} else {ans += value;}}return ans;
}

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

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

相关文章

编码规范阅《数学之美》有感

作为计算机专业的大学生在深入学习编写代码前,我认为应当了解一些大公司内部编码规范的核心要素,遵守这些编码规范不仅有助于提高代码质量,而且也是专业发展的必要条件。通过这些规范,可以更好地帮助自己打牢基础,养成良好的编程习惯,同时也为日后进入职场做准备,以适应…

2-5Java多态

Java 多态 多态是同一个行为具有多个不同表现形式或形态的能力。 多态就是同一个接口,使用不同的实例而执行不同操作,如图所示:多态性是对象多种表现形式的体现。 现实中,比如我们按下 F1 键这个动作:如果当前在 Flash 界面下弹出的就是 AS 3 的帮助文档; 如果当前在 Wor…

四剑客_正则

1 四剑客 1.1 概述 1.2 find命令基本用法 1.2.1 找出/etc/目录下面以.conf结尾的文件⭐⭐⭐⭐⭐ [root@Kylin-V10-sp3 ~/test]# find /etc/ -type f -name *.conf | head -5 /etc/resolv.conf /etc/dnf/protected.d/systemd.conf /etc/dnf/protected.d/sudo.conf /etc/dnf/prot…

今日总结

今天进行了java代码的编写,我学会了很多,我认为我还有很多的不足 我要继续的学习java,我对它的了解还是不够的深

课堂测试

今天的题我没写出来,还是没学明白。之前的题仅仅只是看了看答案,没有自己尝试写一遍,导致今天调试的时候出现错误,最后没整出来,不开心

用Python实现阿拉伯数字转换成中国汉字

本文简要介绍了要将阿拉伯数字转换成中国汉字表示的数字的方法,我们需要一个映射表来转换每个数字,并且处理不同位数的数字(如十、百、千、万等),给出了详细的代码示例和解释。要将阿拉伯数字转换成中国汉字表示的数字,我们需要一个映射表来转换每个数字,并且处理不同位…

P1066

布什各门,阿? 令人惊奇的题解 标程:某个姓组合的数学+高精 here