/** * File: array_binary_tree.cs * Created Time: 2023-07-20 * Author: hpstory (hpstory1024@163.com) */ namespace hello_algo.chapter_tree; /* 数组表示下的二叉树类 */ public class ArrayBinaryTree { private readonly List tree; /* 构造方法 */ public ArrayBinaryTree(List arr) { tree = new List(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 = new(); // 直接遍历数组 for (int i = 0; i < Size(); i++) { if (Val(i).HasValue) res.Add(Val(i).Value); } return res; } /* 深度优先遍历 */ private 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 = new(); Dfs(0, "pre", res); return res; } /* 中序遍历 */ public List InOrder() { List res = new(); Dfs(0, "in", res); return res; } /* 后序遍历 */ public List PostOrder() { List res = new(); Dfs(0, "post", res); return res; } } public class array_binary_tree { [Test] public void Test() { // 初始化二叉树 // 这里借助了一个从数组直接生成二叉树的函数 List arr = new() { 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()); } }