Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

New feature: Support for converting numbers in a larger range. #12576

Open
wants to merge 21 commits into
base: master
Choose a base branch
from
Open
Changes from all commits
Commits
Show all changes
21 commits
Select commit Hold shift + click to select a range
5de6f72
New feature: Support for converting numbers in a larger range.
lighting9999 Feb 10, 2025
1e48591
[pre-commit.ci] auto fixes from pre-commit.com hooks
pre-commit-ci[bot] Feb 10, 2025
f5cdd52
Update roman_numerals.py
lighting9999 Feb 10, 2025
eb8598f
Update roman_numerals.py
lighting9999 Feb 10, 2025
ad28671
[pre-commit.ci] auto fixes from pre-commit.com hooks
pre-commit-ci[bot] Feb 10, 2025
8499e59
Update roman_numerals.py
lighting9999 Feb 10, 2025
99a081b
Update roman_numerals.py
lighting9999 Feb 10, 2025
bcfd98c
Update roman_numerals.py
lighting9999 Feb 10, 2025
1735aed
[pre-commit.ci] auto fixes from pre-commit.com hooks
pre-commit-ci[bot] Feb 10, 2025
6bff121
Update roman_numerals.py
lighting9999 Feb 10, 2025
dd13fe2
[pre-commit.ci] auto fixes from pre-commit.com hooks
pre-commit-ci[bot] Feb 10, 2025
8b10293
Update roman_numerals.py
lighting9999 Feb 10, 2025
5e41453
[pre-commit.ci] auto fixes from pre-commit.com hooks
pre-commit-ci[bot] Feb 10, 2025
657073d
Update roman_numerals.py
lighting9999 Feb 10, 2025
da299d4
[pre-commit.ci] auto fixes from pre-commit.com hooks
pre-commit-ci[bot] Feb 10, 2025
ba43420
Update roman_numerals.py
lighting9999 Feb 10, 2025
e6ea0ba
[pre-commit.ci] auto fixes from pre-commit.com hooks
pre-commit-ci[bot] Feb 10, 2025
07721a8
Update roman_numerals.py
lighting9999 Feb 10, 2025
668b78a
[pre-commit.ci] auto fixes from pre-commit.com hooks
pre-commit-ci[bot] Feb 10, 2025
f4682f1
Update roman_numerals.py
lighting9999 Feb 10, 2025
30a49b3
[pre-commit.ci] auto fixes from pre-commit.com hooks
pre-commit-ci[bot] Feb 10, 2025
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
54 changes: 26 additions & 28 deletions conversions/roman_numerals.py
Original file line number Diff line number Diff line change
@@ -1,4 +1,16 @@
ROMAN = [
(1000000, "M_"),
(900000, "C_M_"),
(500000, "D_"),
(400000, "C_D_"),
(100000, "C_"),
(90000, "X_C_"),
(50000, "L_"),
(40000, "X_L_"),
(10000, "X_"),
(9000, "I_X_"),
(5000, "V_"),
(4000, "I_V_"),
(1000, "M"),
(900, "CM"),
(500, "D"),
Expand All @@ -15,40 +27,26 @@
]


def roman_to_int(roman: str) -> int:
"""
LeetCode No. 13 Roman to Integer
Given a roman numeral, convert it to an integer.
Input is guaranteed to be within the range from 1 to 3999.
https://en.wikipedia.org/wiki/Roman_numerals
>>> tests = {"III": 3, "CLIV": 154, "MIX": 1009, "MMD": 2500, "MMMCMXCIX": 3999}
>>> all(roman_to_int(key) == value for key, value in tests.items())
True
"""
vals = {"I": 1, "V": 5, "X": 10, "L": 50, "C": 100, "D": 500, "M": 1000}
total = 0
place = 0
while place < len(roman):
if (place + 1 < len(roman)) and (vals[roman[place]] < vals[roman[place + 1]]):
total += vals[roman[place + 1]] - vals[roman[place]]
place += 2
def roman_to_int(roman):
vals = {roman: arabic for arabic, roman in ROMAN}
i, total = 0, 0
while i < len(roman):
if i + 1 < len(roman) and roman[i + 1] == "_":
total += vals[roman[i] + "_"]
i += 2
else:
total += vals[roman[place]]
place += 1
total += vals[roman[i]]
i += 1
return total


def int_to_roman(number: int) -> str:
"""
Given a integer, convert it to an roman numeral.
https://en.wikipedia.org/wiki/Roman_numerals
>>> tests = {"III": 3, "CLIV": 154, "MIX": 1009, "MMD": 2500, "MMMCMXCIX": 3999}
>>> all(int_to_roman(value) == key for key, value in tests.items())
True
"""
def int_to_roman(number):
if not isinstance(number, int) or number <= 0:
raise ValueError("Input must be a positive integer greater than 0")

result = []
for arabic, roman in ROMAN:
(factor, number) = divmod(number, arabic)
factor, number = divmod(number, arabic)
result.append(roman * factor)
if number == 0:
break
Expand Down