Skip to content

Commit 6284a25

Browse files
authored
Merge pull request #614 from fartem/2351_First_Letter_to_Appear_Twice
2024-04-30 v. 5.5.7: added "2351. First Letter to Appear Twice"
2 parents 94efb4b + 8ba07d3 commit 6284a25

File tree

4 files changed

+33
-1
lines changed

4 files changed

+33
-1
lines changed

README.md

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -417,3 +417,4 @@ Profile on LeetCode: [fartem](https://leetcode.com/fartem/).
417417
| 2335. Minimum Amount of Time to Fill Cups | [Link](https://leetcode.com/problems/minimum-amount-of-time-to-fill-cups/) | [Link](./lib/easy/2335_minimum_amount_of_time_to_fill_cups.rb) |
418418
| 2341. Maximum Number of Pairs in Array | [Link](https://leetcode.com/problems/maximum-number-of-pairs-in-array/) | [Link](./lib/easy/2341_maximum_number_of_pairs_in_array.rb) |
419419
| 2347. Best Poker Hand | [Link](https://leetcode.com/problems/best-poker-hand/) | [Link](./lib/easy/2347_best_poker_hand.rb) |
420+
| 2351. First Letter to Appear Twice | [Link](https://leetcode.com/problems/first-letter-to-appear-twice/) | [Link](./lib/easy/2351_first_letter_to_appear_twice.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.5.6'
8+
s.version = '5.5.7'
99
s.license = 'MIT'
1010
s.files = ::Dir['lib/**/*.rb'] + %w[bin/leetcode-ruby README.md LICENSE]
1111
s.executable = 'leetcode-ruby'
Lines changed: 15 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,15 @@
1+
# frozen_string_literal: true
2+
3+
# https://leetcode.com/problems/first-letter-to-appear-twice/
4+
# @param {String} s
5+
# @return {Character}
6+
def repeated_character(s)
7+
letters = ::Array.new(128, 0)
8+
s.each_char do |c|
9+
return c if letters[c.ord] == 1
10+
11+
letters[c.ord] += 1
12+
end
13+
14+
'0'
15+
end
Lines changed: 16 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,16 @@
1+
# frozen_string_literal: true
2+
3+
require_relative '../test_helper'
4+
require_relative '../../lib/easy/2351_first_letter_to_appear_twice'
5+
require 'minitest/autorun'
6+
7+
class FirstLetterToAppearTwiceTest < ::Minitest::Test
8+
def test_default
9+
assert_equal('c', repeated_character('abccbaacz'))
10+
assert_equal('d', repeated_character('abcdd'))
11+
end
12+
13+
def test_additional
14+
assert_equal('0', repeated_character('abc'))
15+
end
16+
end

0 commit comments

Comments
 (0)