mirror of
https://github.com/krahets/hello-algo.git
synced 2026-06-16 07:08:21 +08:00
Migrate to Zensical (#1869)
* Fix Russian Ruby code extraction. * Add zensical configs.
This commit is contained in:
@@ -7,19 +7,19 @@ Author: Xuan Khoa Tu Nguyen (ngxktuzkai2000@gmail.com)
|
||||
require_relative '../utils/tree_node'
|
||||
require_relative '../utils/print_util'
|
||||
|
||||
# ## Класс двоичного дерева в массивном представлении ###
|
||||
### Класс двоичного дерева в массивном представлении ###
|
||||
class ArrayBinaryTree
|
||||
# ## Конструктор ###
|
||||
### Конструктор ###
|
||||
def initialize(arr)
|
||||
@tree = arr.to_a
|
||||
end
|
||||
|
||||
# ## Вместимость списка ###
|
||||
### Вместимость списка ###
|
||||
def size
|
||||
@tree.length
|
||||
end
|
||||
|
||||
# ## Получить значение узла с индексом i ###
|
||||
### Получить значение узла с индексом i ###
|
||||
def val(i)
|
||||
# Если индекс выходит за границы, вернуть nil, обозначающий пустую ячейку
|
||||
return if i < 0 || i >= size
|
||||
@@ -27,22 +27,22 @@ class ArrayBinaryTree
|
||||
@tree[i]
|
||||
end
|
||||
|
||||
# ## Получить индекс левого дочернего узла узла с индексом i ###
|
||||
### Получить индекс левого дочернего узла узла с индексом i ###
|
||||
def left(i)
|
||||
2 * i + 1
|
||||
end
|
||||
|
||||
# ## Получить индекс правого дочернего узла узла с индексом i ###
|
||||
### Получить индекс правого дочернего узла узла с индексом i ###
|
||||
def right(i)
|
||||
2 * i + 2
|
||||
end
|
||||
|
||||
# ## Получить индекс родительского узла узла с индексом i ###
|
||||
### Получить индекс родительского узла узла с индексом i ###
|
||||
def parent(i)
|
||||
(i - 1) / 2
|
||||
end
|
||||
|
||||
# ## Обход в ширину ###
|
||||
### Обход в ширину ###
|
||||
def level_order
|
||||
@res = []
|
||||
|
||||
@@ -54,7 +54,7 @@ class ArrayBinaryTree
|
||||
@res
|
||||
end
|
||||
|
||||
# ## Обход в глубину ###
|
||||
### Обход в глубину ###
|
||||
def dfs(i, order)
|
||||
return if val(i).nil?
|
||||
# Предварительный обход
|
||||
@@ -67,21 +67,21 @@ class ArrayBinaryTree
|
||||
@res << val(i) if order == :post
|
||||
end
|
||||
|
||||
# ## Предварительный обход ###
|
||||
### Предварительный обход ###
|
||||
def pre_order
|
||||
@res = []
|
||||
dfs(0, :pre)
|
||||
@res
|
||||
end
|
||||
|
||||
# ## Симметричный обход ###
|
||||
### Симметричный обход ###
|
||||
def in_order
|
||||
@res = []
|
||||
dfs(0, :in)
|
||||
@res
|
||||
end
|
||||
|
||||
# ## Обратный обход ###
|
||||
### Обратный обход ###
|
||||
def post_order
|
||||
@res = []
|
||||
dfs(0, :post)
|
||||
|
||||
Reference in New Issue
Block a user