Skip to content

Commit aeb3c4c

Browse files
authored
Merge pull request #754 from fartem/331_Verify_Preorder_Serialization_of_a_Binary_Tree
2024-10-23 v. 6.8.7: added "331. Verify Preorder Serialization of a Binary Tree"
2 parents ac7df6f + 9b94b3c commit aeb3c4c

File tree

4 files changed

+55
-1
lines changed

4 files changed

+55
-1
lines changed

README.md

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -552,3 +552,4 @@ Profile on LeetCode: [fartem](https://leetcode.com/fartem/).
552552
| 316. Remove Duplicate Letters | [Link](https://leetcode.com/problems/remove-duplicate-letters/) | [Link](./lib/medium/316_remove_duplicate_letters.rb) | [Link](./test/medium/test_316_remove_duplicate_letters.rb) |
553553
| 318. Maximum Product of Word Lengths | [Link](https://leetcode.com/problems/maximum-product-of-word-lengths/) | [Link](./lib/medium/318_maximum_product_of_word_lengths.rb) | [Link](./test/medium/test_318_maximum_product_of_word_lengths.rb) |
554554
| 328. Odd Even Linked List | [Link](https://leetcode.com/problems/odd-even-linked-list/) | [Link](./lib/medium/328_odd_even_linked_list.rb) | [Link](./test/medium/test_328_odd_even_linked_list.rb) |
555+
| 331. Verify Preorder Serialization of a Binary Tree | [Link](https://leetcode.com/problems/verify-preorder-serialization-of-a-binary-tree/) | [Link](./lib/medium/331_verify_preorder_serialization_of_a_binary_tree.rb) | [Link](./test/medium/test_331_verify_preorder_serialization_of_a_binary_tree.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 = '6.8.6'
8+
s.version = '6.8.7'
99
s.license = 'MIT'
1010
s.files = ::Dir['lib/**/*.rb'] + %w[README.md]
1111
s.executable = 'leetcode-ruby'
Lines changed: 22 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,22 @@
1+
# frozen_string_literal: true
2+
3+
# https://leetcode.com/problems/verify-preorder-serialization-of-a-binary-tree/
4+
# @param {String} preorder
5+
# @return {Boolean}
6+
def is_valid_serialization(preorder)
7+
stack = []
8+
tree = preorder.split(',')
9+
tree.each do |node|
10+
while node == '#' && !stack.empty? && stack.last == '#'
11+
stack.pop
12+
13+
return false if stack.empty?
14+
15+
stack.pop
16+
end
17+
18+
stack.push(node)
19+
end
20+
21+
stack.size == 1 && stack.first == '#'
22+
end
Lines changed: 31 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,31 @@
1+
# frozen_string_literal: true
2+
3+
require_relative '../test_helper'
4+
require_relative '../../lib/medium/331_verify_preorder_serialization_of_a_binary_tree'
5+
require 'minitest/autorun'
6+
7+
class VerifyPreorderSerializationOfABinaryTreeTest < ::Minitest::Test
8+
def test_default_one
9+
assert(
10+
is_valid_serialization(
11+
'9,3,4,#,#,1,#,#,2,#,6,#,#'
12+
)
13+
)
14+
end
15+
16+
def test_default_two
17+
assert(
18+
!is_valid_serialization(
19+
'1,#'
20+
)
21+
)
22+
end
23+
24+
def test_default_three
25+
assert(
26+
!is_valid_serialization(
27+
'9,#,#,1'
28+
)
29+
)
30+
end
31+
end

0 commit comments

Comments
 (0)