-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy path12.intToRoman.py
More file actions
56 lines (51 loc) · 1.06 KB
/
12.intToRoman.py
File metadata and controls
56 lines (51 loc) · 1.06 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
class Solution:
def intToRoman(self, num):
"""
:type num: int
:rtype: str
"""
roman = convert4(num // 1000)
num %= 1000
roman += convert3(num // 100)
num %= 100
roman += convert2(num // 10)
num %= 10
roman += convert1(num)
return roman
def convert1(num):
if num == 0:
return ''
if num < 4:
return "I" * num
if num == 4:
return "IV"
if num < 9:
return "V" + "I" * (num - 5)
if num == 9:
return "IX"
def convert2(num):
if num == 0:
return ''
if num < 4:
return "X" * num
if num == 4:
return "XL"
if num < 9:
return "L" + "X" * (num - 5)
if num == 9:
return "XC"
def convert3(num):
if num == 0:
return ''
if num < 4:
return "C" * num
if num == 4:
return "CD"
if num < 9:
return "D" + "C" * (num - 5)
if num == 9:
return "CM"
def convert4(num):
if num == 0:
return ''
return "M" * num