内容简介:罗马数字包含以下七种字符:例如, 罗马数字通常情况下,罗马数字中小的数字在大的数字的右边。但也存在特例,例如
LeetCode12.整数转罗马数字 JavaScript
罗马数字包含以下七种字符: 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
到 3999
的范围内。
示例 1:
输入: 3
示例 2:
输入: 4
示例 3:
输入: 9
示例 4:
输入: 58
输出: "LVIII"
解释: L = 50, V = 5, III = 3.
示例 5:
输入: 1994
输出: "MCMXCIV"
解释: M = 1000, CM = 900, XC = 90, IV = 4.
答案参考:
/** * @param {number} num * @return {string} */ var intToRoman = function(num) { let M = ["", "M", "MM", "MMM"]; let C = ["", "C", "CC", "CCC", "CD", "D", "DC", "DCC", "DCCC", "CM"]; let X = ["", "X", "XX", "XXX", "XL", "L", "LX", "LXX", "LXXX", "XC"]; let I = ["", "I", "II", "III", "IV", "V", "VI", "VII", "VIII", "IX"]; return M[parseInt(num/1000)] + C[parseInt((num%1000)/100)] + X[parseInt((num%100)/10)] + I[num%10]; };
以上所述就是小编给大家介绍的《LeetCode12.整数转罗马数字 JavaScript》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!
猜你喜欢:- JavaScript 转换数字为整数的方法
- 让我们一起啃算法----罗马数字转整数
- 每日一道 LeetCode (4):罗马数字转整数
- LeetCode题库13. 罗马数字转整数(c++实现)
- 如何在1到100的整数数组上找到缺失的数字
- LeetCode - 013 - 罗马数字转整数(roman-to-integer)
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。