题目描述:
罗马数字包含以下七种字符: 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
输出: "III"
之前做过一道罗马数组转数字的题目,当时是将键值对保存在了Map里面,然后从头到尾遍历字符串,依次判断前一位所对应的值是否比后一位小,依次计算。
本体刚好相反,最开始我的想法是,对该数个十百千位进行判断,但是发现这样子并不好算。随后网上看了其他大神的解答,注意到,其实,完全可以将以“前一位比后一位小”的这种情况所表达的数字,和已经给出的数字看做同等级的数字存在,即在新建某一数据结构存储数据时,可以将类似900,400,90,9,4之类的数字与已经给出的数字一起存起来
int[] nums = {1000, 900, 500, 400, 100, 90, 50, 40, 10, 9, 5, 4, 1};
String[] romans = {"M", "CM", "D", "CD", "C", "XC", "L", "XL", "X", "IX", "V", "IV", "I"};
新建一个StringBuilder,然后将给出的数字从大位到小位依次判断,例如,3241,先判断3241是否大于1000,若大于,则在StringBuilder中append一个M,然后3241-1000=2241,2241是否大于1000,是,则append一个M,1241是否大于1000,是,append一个M,241不大于1000,是否大于900,不是,是否大于500,不是,是否大于400,不是,是否大于100,是,append一个C。。。。。。
public class Solution {
public String intToRoman(int num) {
// 把阿拉伯数字与罗马数字可能出现的所有情况和对应关系,放在两个数组中
// 并且按照阿拉伯数字的大小降序排列,这是贪心选择思想
int[] nums = {1000, 900, 500, 400, 100, 90, 50, 40, 10, 9, 5, 4, 1};
String[] romans = {"M", "CM", "D", "CD", "C", "XC", "L", "XL", "X", "IX", "V", "IV", "I"};
StringBuilder stringBuilder = new StringBuilder();
int index = 0;
while (index < 13) {
// 特别注意:这里是等号
while (num >= nums[index]) {
// 注意:这里是等于号,表示尽量使用大的"面值"
stringBuilder.append(romans[index] + " ");
num -= nums[index];
}
index++;
}
return stringBuilder.toString();
}
}
作者:liweiwei1419
链接:https://leetcode-cn.com/problems/integer-to-roman/solution/tan-xin-suan-fa-by-liweiwei1419/
来源:力扣(LeetCode)
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。