C#分別用前序遍歷、中序遍歷和后序遍歷打印二叉樹

bdnp 9年前發布 | 3K 次閱讀 C# 算法

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);
}      </pre> 


 本文由用戶 bdnp 自行上傳分享,僅供網友學習交流。所有權歸原作者,若您的權利被侵害,請聯系管理員。
 轉載本站原創文章,請注明出處,并保留原始鏈接、圖片水印。
 本站是一個以用戶分享為主的開源技術平臺,歡迎各類分享!