9.3.4. Преобразование дерева в строку или массив
9.3.4. Преобразование дерева в строку или массив
С помощью тех же приемов, которые применяются для обхода дерева, мы можем преобразовать его в строку или в массив. Ниже мы выполняем обход во внутреннем порядке, хотя подошел бы и любой другой способ:
class Tree
# Предполагается, что определения взяты из предыдущего примера...
def to_s
"[" +
if left then left.to_s + "," else "" end +
data.inspect +
if right then "," + right.to_s else "" end + "]"
end
def to_a
temp = []
temp += left.to_a if left
temp << data
temp += right.to_a if right
temp
end
end
items = %w[bongo grimace monoid jewel plover nexus synergy]
tree = Tree.new
items.each {|x| tree.insert x}
str = tree.to_a * ","
# str is now "bongo,grimace,jewel,monoid,nexus,plover,synergy"
arr = tree.to_a
# arr равно:
# ["bongo",["grimace",[["jewel"],"monoid",[["nexus"],"plover",
# ["synergy"]]]]]
Отметим, что глубина вложенности получающегося массива равна глубине дерева с корнем в том узле, с которого мы начали обход. Чтобы получить плоский массив, можете воспользоваться методом flatten.
Более 800 000 книг и аудиокниг! 📚
Получи 2 месяца Литрес Подписки в подарок и наслаждайся неограниченным чтением
ПОЛУЧИТЬ ПОДАРОКДанный текст является ознакомительным фрагментом.
Читайте также
14.4.6. Удаление вершины дерева и удаление дерева: tdelete() и tdestroy()
14.4.6. Удаление вершины дерева и удаление дерева: tdelete() и tdestroy() Наконец, вы можете удалить элементы из дерева и, на системах GLIBC, удалить само дерево целиком:void *tdelete(const void *key, void **rootp,int (*compare)(const void*, const void*));/* Расширение GLIBC, в POSIX нет: */void tdestroy(void *root, void (*free_node)(void *nodep));Аргументы
evaluate - Создает новую пустую строку, и вставляет ;
evaluate - Создает новую пустую строку, и вставляет ; evaluateСоздает новую пустую строку, и вставляет ; для того, чтобы можно было ввести свой код в строку Expression панели Actions.Синтаксис:statement;Действие evaluate позволяет вызывать свои функции пользователю, который редактирует скрипт в
Как выделить строку, столбец и ячейки
Как выделить строку, столбец и ячейки Если нужно что-то проделать с текстом одновременно в нескольких ячейках, их удобно выделить, используя следующие приемы.• Чтобы выделить столбец, подведите указатель мыши к верхней границе и, когда он примет вид маленькой черной
Прямоугольный массив
Прямоугольный массив Для создания прямоугольного массива установите переключатель в окне Array (Массив) в положение Rectangular Array (Прямоугольный массив). При этом станут доступны следующие параметры.• Для изменения количества строк и столбцов используют поля Rows (Строки) и
Трехмерный массив
Трехмерный массив Для создания трехмерного массива используется команда 3DARRAY. Как и на плоскости, в трехмерном пространстве можно создать два типа массива – прямоугольный и круговой. Только при формировании прямоугольного массива в качестве дополнительного параметра
Круговой массив
Круговой массив Для того чтобы создать круговой трехмерный массив, нажмите кнопку 3D Array (Трехмерный массив) в группе Modify (Редактирование) на вкладке Ноте (Основная) ленты или выполните команду Modify ? 3D Operations ? 3D Array (Редактирование ? Трехмерные операции ? Трехмерный
2.21. Включение выражений в строку
2.21. Включение выражений в строку Это легко позволяет сделать синтаксическая конструкция #{}. Нет нужды думать о преобразовании, добавлении и конкатенации; нужно лишь интерполировать переменную или другое выражение в любое место строки:puts "#{temp_f} по Фаренгейту равно #{temp_c}
6.2.5. Преобразование в массив
6.2.5. Преобразование в массив Когда диапазон преобразуется в массив, интерпретатор последовательно вызывает метод succ, пока не будет достигнута правая граница, и помещает каждый элемент диапазона в возвращаемый массив:r = 3..12arr = r.to_a # [3,4,5,6,7,8,9,10,11,12]Ясно, что для диапазонов
8.1.19. Преобразование массива в строку с разделителями
8.1.19. Преобразование массива в строку с разделителями Часто требуется вставить разделители между элементами массива, но не перед первым и не после последнего. Для этого предназначены метод join и оператор *.been_there = ["Veni", "vidi", "vici."]journal = been_there.join(", ") # "Veni, vidi, vici."letters =
Как не «проморгать» нужную строку
Как не «проморгать» нужную строку Вы, думаю, помните, сколько всего выводится на экран при сборке ядра или какого-нибудь большого пакета. Постоянно наблюдать за выводом довольно скучно, а экранный буфер не всегда позволяет «отмотать» вывод до интересующего вас момента.
Прямоугольный массив
Прямоугольный массив Для создания прямоугольного массива установите переключатель в окне Array (Массив) в положение Rectangular Array (Прямоугольный массив) (см. рис. 6.7). При этом станут доступны следующие параметры.• Для изменения количества строк и столбцов используют поля Rows
Полярный массив
Полярный массив Для создания полярного массива установите переключатель в окне Array (Массив) в положение Polar Array (Полярный массив) (рис. 6.11). Рис. 6.11. Окно создания полярного массиваПри этом становятся доступны следующие параметры.• Поля X и Y служат для указания центра