Migrate to Zensical (#1869)

* Fix Russian Ruby code extraction.

* Add zensical configs.
This commit is contained in:
Yudong Jin
2026-03-29 05:41:25 +08:00
committed by GitHub
parent bc4c5ec414
commit 7a78369e4c
84 changed files with 1302 additions and 445 deletions

View File

@@ -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)