手机
当前位置:查字典教程网 >编程开发 >C#教程 >C#使用前序遍历、中序遍历和后序遍历打印二叉树的方法
C#使用前序遍历、中序遍历和后序遍历打印二叉树的方法
摘要:本文实例讲述了C#使用前序遍历、中序遍历和后序遍历打印二叉树的方法。分享给大家供大家参考。具体实现方法如下:publicclassBinar...

本文实例讲述了C#使用前序遍历、中序遍历和后序遍历打印二叉树的方法。分享给大家供大家参考。具体实现方法如下:

public class BinaryTreeNode { public BinaryTreeNode Left { get; set; } public BinaryTreeNode Right { get; set; } public int Data { get; set; } public BinaryTreeNode(int data) { this.Data = data; } } public enum TreeTraversal { PREORDER, INORDER, POSTORDER } public void PrintTree(BinaryTreeNode root, TreeTraversal treeTraversal) { Action<int> printValue = delegate(int v) { Console.Write(v + " "); }; switch (treeTraversal) { case TreeTraversal.PREORDER: PreOrderTraversal(printValue, root); break; case TreeTraversal.INORDER: InOrderTraversal(printValue, root); break; case TreeTraversal.POSTORDER: PostOrderTraversal(printValue, root); break; default: break; } } public void PreOrderTraversal(Action<int> action, BinaryTreeNode root) { if (root == null) return; action(root.Data); PreOrderTraversal(action, root.Left); PreOrderTraversal(action, root.Right); } public void InOrderTraversal(Action<int> action, BinaryTreeNode root) { if (root == null) return; InOrderTraversal(action, root.Left); action(root.Data); InOrderTraversal(action, root.Right); } public void PostOrderTraversal(Action<int> action, BinaryTreeNode root) { if (root == null) return; PostOrderTraversal(action, root.Left); PostOrderTraversal(action, root.Right); action(root.Data); }

希望本文所述对大家的C#程序设计有所帮助。

【C#使用前序遍历、中序遍历和后序遍历打印二叉树的方法】相关文章:

C#计算代码执行时间的方法

C#.NET字符串比较中忽略符号的方法

用NPOI创建Excel、合并单元格、设置单元格样式、边框的方法

C# 改变无边框窗体尺寸大小的方法

C#中执行批处理文件(*.bat)的方法代码

基于c#图像灰度化、灰度反转、二值化的实现方法详解

C# 获取打印机当前状态的方法

C#中Web.Config加密与解密的方法

用C#对ADO.NET数据库完成简单操作的方法

c# 对cookies(增、删、改、查)的操作方法

精品推荐
分类导航