Skip to content

Commit 759c278

Browse files
committed
2024-04-12 v. 5.4.5: added "2287. Rearrange Characters to Make Target String"
1 parent f033aec commit 759c278

4 files changed

+39
-1
lines changed

README.md

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -405,3 +405,4 @@ Profile on LeetCode: [fartem](https://leetcode.com/fartem/).
405405
| 2264. Largest 3-Same-Digit Number in String | [Link](https://leetcode.com/problems/largest-3-same-digit-number-in-string/) | [Link](./lib/easy/2264_largest_3_same_digit_number_in_string.rb) |
406406
| 2278. Percentage of Letter in String | [Link](https://leetcode.com/problems/percentage-of-letter-in-string/) | [Link](./lib/easy/2278_percentage_of_letter_in_string.rb) |
407407
| 2283. Check if Number Has Equal Digit Count and Digit Value | [Link](https://leetcode.com/problems/check-if-number-has-equal-digit-count-and-digit-value/) | [Link](./lib/easy/2283_check_if_number_has_equal_digit_count_and_digit_value.rb) |
408+
| 2287. Rearrange Characters to Make Target String | [Link](https://leetcode.com/problems/rearrange-characters-to-make-target-string/) | [Link](./lib/easy/2287_rearrange_characters_to_make_target_string.rb) |

leetcode-ruby.gemspec

Lines changed: 1 addition & 1 deletion
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.4.4'
8+
s.version = '5.4.5'
99
s.license = 'MIT'
1010
s.files = ::Dir['lib/**/*.rb'] + %w[bin/leetcode-ruby README.md LICENSE]
1111
s.executable = 'leetcode-ruby'
Lines changed: 24 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,24 @@
1+
# frozen_string_literal: true
2+
3+
# https://leetcode.com/problems/rearrange-characters-to-make-target-string/
4+
# @param {String} s
5+
# @param {String} target
6+
# @return {Integer}
7+
def rearrange_characters(s, target)
8+
s_count = ::Array.new(26, 0)
9+
s.each_byte { |b| s_count[b - 97] += 1 }
10+
11+
t_count = ::Array.new(26, 0)
12+
target.each_byte { |b| t_count[b - 97] += 1 }
13+
14+
result = 1_000_000_000_000_000
15+
(0...t_count.length).each do |i|
16+
next if t_count[i].zero?
17+
18+
return 0 if s_count[i].zero?
19+
20+
result = [result, s_count[i] / t_count[i]].min
21+
end
22+
23+
result
24+
end
Lines changed: 13 additions & 0 deletions
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/easy/2287_rearrange_characters_to_make_target_string'
5+
require 'minitest/autorun'
6+
7+
class RearrangeCharactersToMakeTargetStringTest < ::Minitest::Test
8+
def test_default
9+
assert_equal(2, rearrange_characters('ilovecodingonleetcode', 'code'))
10+
assert_equal(1, rearrange_characters('abcba', 'abc'))
11+
assert_equal(1, rearrange_characters('abbaccaddaeea', 'aaaaa'))
12+
end
13+
end

0 commit comments

Comments
 (0)