Skip to content

Commit d09a8d1

Browse files
authored
Merge pull request #657 from fartem/12_Integer_to_Roman
2024-07-01 v. 6.0.0: added "12. Integer to Roman"
2 parents edf21a2 + de56eef commit d09a8d1

File tree

4 files changed

+47
-1
lines changed

4 files changed

+47
-1
lines changed

README.md

+1
Original file line numberDiff line numberDiff line change
@@ -465,3 +465,4 @@ Profile on LeetCode: [fartem](https://leetcode.com/fartem/).
465465
| 7. Reverse Integer | [Link](https://leetcode.com/problems/reverse-integer/) | [Link](./lib/medium/7_reverse_integer.rb) |
466466
| 8. String to Integer (atoi) | [Link](https://leetcode.com/problems/string-to-integer-atoi/) | [Link](./lib/medium/8_string_to_integer_atoi.rb) |
467467
| 11. Container With Most Water | [Link](https://leetcode.com/problems/container-with-most-water/) | [Link](./lib/medium/11_container_with_most_water.rb) |
468+
| 12. Integer to Roman | [Link](https://leetcode.com/problems/integer-to-roman/) | [Link](./lib/medium/12_integer_to_roman.rb) |

leetcode-ruby.gemspec

+1-1
Original file line numberDiff line numberDiff line change
@@ -5,7 +5,7 @@ require 'English'
55
::Gem::Specification.new do |s|
66
s.required_ruby_version = '>= 3.0'
77
s.name = 'leetcode-ruby'
8-
s.version = '5.9.9'
8+
s.version = '6.0.0'
99
s.license = 'MIT'
1010
s.files = ::Dir['lib/**/*.rb'] + %w[bin/leetcode-ruby README.md LICENSE]
1111
s.executable = 'leetcode-ruby'

lib/medium/12_integer_to_roman.rb

+32
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,32 @@
1+
# frozen_string_literal: false
2+
3+
# https://leetcode.com/problems/integer-to-roman/
4+
# @param {Integer} num
5+
# @return {String}
6+
def int_to_roman(num)
7+
roman_numbers = {
8+
1000 => 'M',
9+
900 => 'CM',
10+
500 => 'D',
11+
400 => 'CD',
12+
100 => 'C',
13+
90 => 'XC',
14+
50 => 'L',
15+
40 => 'XL',
16+
10 => 'X',
17+
9 => 'IX',
18+
5 => 'V',
19+
4 => 'IV',
20+
1 => 'I'
21+
}
22+
23+
result = ''
24+
roman_numbers.each do |value, symbol|
25+
while num >= value
26+
result << symbol
27+
num -= value
28+
end
29+
end
30+
31+
result
32+
end
+13
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,13 @@
1+
# frozen_string_literal: true
2+
3+
require_relative '../test_helper'
4+
require_relative '../../lib/medium/12_integer_to_roman'
5+
require 'minitest/autorun'
6+
7+
class IntegerToRomanTest < ::Minitest::Test
8+
def test_default
9+
assert_equal('MMMDCCXLIX', int_to_roman(3749))
10+
assert_equal('LVIII', int_to_roman(58))
11+
assert_equal('MCMXCIV', int_to_roman(1994))
12+
end
13+
end

0 commit comments

Comments
 (0)