LeetCode之Easy篇 ——(12)Roman to Integer
阿新 • • 發佈:2018-03-19
三次 所表 舉例 重復 str put size input inpu
Given an integer, convert it to a roman numeral.
Input is guaranteed to be within the range from 1 to 3999.
羅馬數字:
基本字符 | I | V | X | L | C | D | M |
---|---|---|---|---|---|---|---|
相應的阿拉伯數字表示為 | 1 | 5 | 10 | 50 | 100 | 500 | 1000 |
1、相同的數字連寫、所表示的數等於這些數字相加得到的數、如:Ⅲ=3;
2、小的數字在大的數字的右邊、所表示的數等於這些數字相加得到的數、 如:Ⅷ=8、Ⅻ=12;
3、小的數字(限於 I、X 和 C)在大的數字的左邊、所表示的數等於大數減小數得到的數、如:Ⅳ=4、Ⅸ=9;
4、正常使用時、連寫的數字重復不得超過三次;
5、在一個數的上面畫一條橫線、表示這個數擴大 1000 倍。
思路:
首先,用二維數組保存羅馬數字的個位、整十、整百、整千(如1000、2000...其他類似)。舉例:[0][1]代表“I”,[1][0]代表X,[1][1]代表XX。
其次,將輸入值的各位取出來,再輸出對應數組裏的羅馬字符。舉例:若取出來的是百位上的3,則對應數組的[2][2],即是它對應的300。
Java代碼實現:
public class Solution { public String intToRoman(int num) { String[][] s = new String[][]{{"", "I", "II", "III", "IV", "V", "VI", "VII", "VIII", "IX"}, {"", "X", "XX", "XXX", "XL", "L", "LX", "LXX", "LXXX", "XC"}, {"", "C", "CC", "CCC", "CD", "D", "DC", "DCC", "DCCC", "CM"}, {"", "M", "MM", "MMM"}}; return s[3][num / 1000 % 10] + s[2][num / 100 % 10] + s[1][num / 10 % 10] + s[0][num % 10]; } }
LeetCode之Easy篇 ——(12)Roman to Integer