12. Integer to Roman

Description

Given an integer, convert it to a roman numeral.

Input is guaranteed to be within the range from 1 to 3999.

Solution

HashMap

找规律,对于4、9这种需要特殊处理,提前存在HashMap中即可。

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

还有人这样写:

public static String intToRoman(int num) {
    String M[] = {"", "M", "MM", "MMM"};
    String C[] = {"", "C", "CC", "CCC", "CD", "D", "DC", "DCC", "DCCC", "CM"};
    String X[] = {"", "X", "XX", "XXX", "XL", "L", "LX", "LXX", "LXXX", "XC"};
    String I[] = {"", "I", "II", "III", "IV", "V", "VI", "VII", "VIII", "IX"};
    return M[num/1000] + C[(num%1000)/100] + X[(num%100)/10] + I[num%10];
}

你可能感兴趣的:(12. Integer to Roman)