12. Integer to Roman LeetCode题解

Given an integer, convert it to a roman numeral.

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

Subscribe to see which companies asked this question.

题意:

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

输入范围是1-3999


题解:

罗马数字规则

有了规则之后,其实可以把对应数位的数事先写出来,再拼接起来;

扫描二维码关注公众号,回复: 2918142 查看本文章


Code【Java】

public class Solution {
    public 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 / 100 % 10] + X[num / 10 % 10] + I[num % 10]);
    }
}

Code【C++】

class Solution {
public:
    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 / 100 % 10] + X[num / 10 % 10] + I[num % 10]);
    }
};


猜你喜欢

转载自blog.csdn.net/baidu_23318869/article/details/72235383