/** * File: array_binary_tree.cs * Created Time: 2023-07-20 * Author: hpstory (hpstory1024@163.com) */ namespace hello_algo.chapter_tree; /* Класс двоичного дерева в массивном представлении */ public class ArrayBinaryTree(List arr) { List tree = new(arr); /* Вместимость списка */ public int Size() { return tree.Count; } /* Получить значение узла с индексом i */ public int? Val(int i) { // Если индекс выходит за границы, вернуть null, обозначающий пустую позицию if (i < 0 || i >= Size()) return null; return tree[i]; } /* Получить индекс левого дочернего узла узла с индексом i */ public int Left(int i) { return 2 * i + 1; } /* Получить индекс правого дочернего узла узла с индексом i */ public int Right(int i) { return 2 * i + 2; } /* Получить индекс родительского узла узла с индексом i */ public int Parent(int i) { return (i - 1) / 2; } /* Обход в ширину */ public List LevelOrder() { List res = []; // Непосредственно обходить массив for (int i = 0; i < Size(); i++) { if (Val(i).HasValue) res.Add(Val(i)!.Value); } return res; } /* Обход в глубину */ void DFS(int i, string order, List res) { // Если это пустая позиция, вернуть if (!Val(i).HasValue) return; // Предварительный обход if (order == "pre") res.Add(Val(i)!.Value); DFS(Left(i), order, res); // Симметричный обход if (order == "in") res.Add(Val(i)!.Value); DFS(Right(i), order, res); // Обратный обход if (order == "post") res.Add(Val(i)!.Value); } /* Предварительный обход */ public List PreOrder() { List res = []; DFS(0, "pre", res); return res; } /* Симметричный обход */ public List InOrder() { List res = []; DFS(0, "in", res); return res; } /* Обратный обход */ public List PostOrder() { List res = []; DFS(0, "post", res); return res; } } public class array_binary_tree { [Test] public void Test() { // Инициализировать двоичное дерево // Здесь используется функция, напрямую строящая двоичное дерево из массива List arr = [1, 2, 3, 4, null, 6, 7, 8, 9, null, null, 12, null, null, 15]; TreeNode? root = TreeNode.ListToTree(arr); Console.WriteLine("\nИнициализация двоичного дерева\n"); Console.WriteLine("Массивное представление двоичного дерева:"); Console.WriteLine(arr.PrintList()); Console.WriteLine("Связное представление двоичного дерева:"); PrintUtil.PrintTree(root); // Класс двоичного дерева в массивном представлении ArrayBinaryTree abt = new(arr); // Доступ к узлу int i = 1; int l = abt.Left(i); int r = abt.Right(i); int p = abt.Parent(i); Console.WriteLine("\nТекущий узел: индекс = " + i + " , значение = " + abt.Val(i)); Console.WriteLine("Индекс левого дочернего узла = " + l + " , значение = " + (abt.Val(l).HasValue ? abt.Val(l) : "null")); Console.WriteLine("Индекс правого дочернего узла = " + r + " , значение = " + (abt.Val(r).HasValue ? abt.Val(r) : "null")); Console.WriteLine("Индекс родительского узла = " + p + " , значение = " + (abt.Val(p).HasValue ? abt.Val(p) : "null")); // Обходить дерево List res = abt.LevelOrder(); Console.WriteLine("\nОбход в ширину = " + res.PrintList()); res = abt.PreOrder(); Console.WriteLine("Предварительный обход = " + res.PrintList()); res = abt.InOrder(); Console.WriteLine("Симметричный обход = " + res.PrintList()); res = abt.PostOrder(); Console.WriteLine("Обратный обход = " + res.PrintList()); } }