-
Notifications
You must be signed in to change notification settings - Fork 17
/
Copy pathinteger-to-english-words.py
121 lines (98 loc) · 3.24 KB
/
integer-to-english-words.py
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
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
from typing import List
class Solution:
def numberToWords(self, num: int) -> str:
power_to_word = {
3: "Thousand",
6: "Million",
9: "Billion",
}
digit_to_word = {
1: "One",
2: "Two",
3: "Three",
4: "Four",
5: "Five",
6: "Six",
7: "Seven",
8: "Eight",
9: "Nine",
}
teen_to_word = {
11: "Eleven",
12: "Twelve",
13: "Thirteen",
14: "Fourteen",
15: "Fifteen",
16: "Sixteen",
17: "Seventeen",
18: "Eighteen",
19: "Nineteen",
}
dozen_to_word = {
1: "Ten",
2: "Twenty",
3: "Thirty",
4: "Forty",
5: "Fifty",
6: "Sixty",
7: "Seventy",
8: "Eighty",
9: "Ninety",
}
def decimal(result: List[str], num: int):
if num == 0:
pass
elif num % 10 == 0:
result.append(dozen_to_word[num // 10])
elif num < 10:
result.append(digit_to_word[num])
elif num < 20:
result.append(teen_to_word[num])
else:
result.append(dozen_to_word[num // 10])
result.append(digit_to_word[num % 10])
def hundred(result: List[str], num: int):
if num >= 100:
result.append(digit_to_word[num // 100])
result.append("Hundred")
decimal(result, num % 100)
def process(num: int) -> str:
result = []
for power in [9, 6, 3, 0]:
if num // (10 ** power) > 0:
hundred(result, num // (10 ** power))
if power > 0:
result.append(power_to_word[power])
num %= 10 ** power
return " ".join(result) if result else "Zero"
return process(num)
class TestSolution:
def setup(self):
self.sol = Solution()
def test_case1(self):
assert self.sol.numberToWords(123) == "One Hundred Twenty Three"
def test_case2(self):
assert (
self.sol.numberToWords(123123)
== "One Hundred Twenty Three Thousand One Hundred Twenty Three"
)
def test_case3(self):
assert (
self.sol.numberToWords(123123123)
== "One Hundred Twenty Three Million One Hundred Twenty Three Thousand One Hundred Twenty Three"
)
def test_case4(self):
assert (
self.sol.numberToWords(123123123123)
== "One Hundred Twenty Three Billion One Hundred Twenty Three Million One Hundred Twenty Three Thousand One Hundred Twenty Three"
)
def test_case5(self):
assert self.sol.numberToWords(0) == "Zero"
def test_case6(self):
assert self.sol.numberToWords(110) == "One Hundred Ten"
def test_case7(self):
assert self.sol.numberToWords(150) == "One Hundred Fifty"
def test_case8(self):
assert self.sol.numberToWords(50) == "Fifty"
def test_case9(self):
assert self.sol.numberToWords(100) == "One Hundred"