Skip to content

Commit 8255192

Browse files
authored
2025-01-08 v. 7.8.1: added "297. Serialize and Deserialize Binary Tree"
2 parents 269a1db + 7c25be2 commit 8255192

File tree

4 files changed

+90
-1
lines changed

4 files changed

+90
-1
lines changed

README.md

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -650,3 +650,4 @@ Profile on LeetCode: [fartem](https://leetcode.com/fartem/).
650650
| 126. Word Ladder II | [Link](https://leetcode.com/problems/word-ladder-ii/) | [Link](./lib/hard/126_word_ladder_ii.rb) | [Link](./test/hard/test_126_word_ladder_ii.rb) |
651651
| 233. Number of Digit One | [Link](https://leetcode.com/problems/number-of-digit-one/) | [Link](./lib/hard/233_number_of_digit_one.rb) | [Link](./test/hard/test_233_number_of_digit_one.rb) |
652652
| 239. Sliding Window Maximum | [Link](https://leetcode.com/problems/sliding-window-maximum/) | [Link](./lib/hard/239_sliding_window_maximum.rb) | [Link](./test/hard/test_239_sliding_window_maximum.rb) |
653+
| 297. Serialize and Deserialize Binary Tree | [Link](https://leetcode.com/problems/serialize-and-deserialize-binary-tree/) | [Link](./lib/hard/297_serialize_and_deserialize_binary_tree.rb) | [Link](./test/hard/test_297_serialize_and_deserialize_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 = '7.8.0'
8+
s.version = '7.8.1'
99
s.license = 'MIT'
1010
s.files = ::Dir['lib/**/*.rb'] + %w[README.md]
1111
s.executable = 'leetcode-ruby'
Lines changed: 38 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,38 @@
1+
# frozen_string_literal: true
2+
3+
# https://leetcode.com/problems/serialize-and-deserialize-binary-tree/
4+
# @param {TreeNode} root
5+
# @return {String}
6+
def serialize_binary_tree(root)
7+
preorder =
8+
lambda do |node|
9+
return [nil] unless node
10+
11+
[node.val] + preorder.call(node.left) + preorder.call(node.right)
12+
end
13+
14+
preorder.call(root).to_json
15+
end
16+
17+
# @param {String} data
18+
# @return {TreeNode}
19+
def deserialize_binary_tree(data)
20+
return if data.empty?
21+
22+
helper =
23+
lambda do |preorder|
24+
return if preorder.empty?
25+
26+
current = preorder.shift
27+
28+
return unless current
29+
30+
root = ::TreeNode.new(current)
31+
root.left = helper.call(preorder)
32+
root.right = helper.call(preorder)
33+
34+
root
35+
end
36+
37+
helper.call(::JSON.parse(data))
38+
end
Lines changed: 50 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,50 @@
1+
# frozen_string_literal: true
2+
3+
require_relative '../test_helper'
4+
require_relative '../../lib/common/binary_tree'
5+
require_relative '../../lib/hard/297_serialize_and_deserialize_binary_tree'
6+
require 'minitest/autorun'
7+
8+
class SerializeAndDeserializeBinaryTreeTest < ::Minitest::Test
9+
def test_default_one
10+
assert(
11+
::TreeNode.are_equals(
12+
::TreeNode.new(
13+
1,
14+
::TreeNode.new(2),
15+
::TreeNode.new(
16+
3,
17+
::TreeNode.new(4),
18+
::TreeNode.new(5)
19+
)
20+
),
21+
deserialize_binary_tree(
22+
serialize_binary_tree(
23+
::TreeNode.new(
24+
1,
25+
::TreeNode.new(2),
26+
::TreeNode.new(
27+
3,
28+
::TreeNode.new(4),
29+
::TreeNode.new(5)
30+
)
31+
)
32+
)
33+
)
34+
)
35+
)
36+
end
37+
38+
def test_default_two
39+
assert(
40+
::TreeNode.are_equals(
41+
nil,
42+
deserialize_binary_tree(
43+
serialize_binary_tree(
44+
nil
45+
)
46+
)
47+
)
48+
)
49+
end
50+
end

0 commit comments

Comments
 (0)