zoukankan      html  css  js  c++  java
  • [转]二叉树遍历算法实现(C#2.0)

    本文转自:http://www.cnblogs.com/xuanfeng/archive/2006/09/20/509897.html

    本人用C#2.0实现了二叉树的定义,怎么构造一颗已知的二叉树,用几种常规的算法(先序,中序,后序,层次)遍历二叉树。希望能给有需要人带来帮助,也希望能得到大家的指点。有关C#数据结构的书在书店里找到,网上也是极少,如果你有好的学习资源别忘了告诉我。先谢了。数据结构对一个程序员来说,现在是太重要了,数据结构学得好的人,逻辑思维一定很强,在程序设计的时候,就不会觉得太费劲了。而且是在设计多层应用程序的时候,真是让人绞尽脑汁啊。趁自己还年轻,赶紧练练脑子。哈哈,咱们尽快进入主题吧。

       本程序中将用到一棵已知的二叉树如图(二叉树图)所示。



     


     下面简单介绍一下几种算法和思路:

    先序遍历:

    1.       访问根结点

    2.       按先序遍历左子树;

    3.       按先序遍历右子树;

    4.       例如:遍历已知二叉树结果为:A->B->D->G->H->C->E->F

    中序遍历:

    1.       按中序遍历左子树;

    2.       访问根结点;

    3.       按中序遍历右子树;

    4.       例如遍历已知二叉树的结果:B->G->D->H->A->E->C->F

    后序遍历:

    1.       按后序遍历左子树;

    2.       按后序遍历右子树;

    3.       访问根结点;

    4.       例如遍历已知二叉树的结果:G->H->D->B->E->F->C->A

    层次遍历:

    1.       从上到下,从左到右遍历二叉树的各个结点(实现时需要借辅助容器);

    2.       例如遍历已知二叉树的结果:A->B->C->D->E->F->G->H

    附加整个解决方案代码:

    二叉遍历算法解决方案
    using System;
    using System.Collections.Generic;
    using System.Text;
    /**//*
     作者:旋风
     日期:2006/9/20
     博客园主页:xuanfeng.cnblogs.com
     
     */

    namespace structure
    {
        class Program
        {
            二叉树结点数据结构的定义#region 二叉树结点数据结构的定义 
            //二叉树结点数据结构包括数据域,左右结点以及父结点成员;
          class nodes<T>
            {
                T data;
                nodes<T> Lnode, Rnode, Pnode;
                public T Data
                {
                    set { data = value; }
                    get { return data; }

                }
                public nodes<T> LNode
                {
                    set { Lnode = value; }
                    get { return Lnode; }
                }
                public nodes<T> RNode
                {
                    set { Rnode = value; }
                    get { return Rnode; }

                }

                public nodes<T> PNode
                {
                    set { Pnode = value; }
                    get { return Pnode; }

                }
              public nodes()
              { }
              public nodes(T data)
              {
                  this.data = data;
              }

            } 
            #endregion

            先序编历二叉树#region 先序编历二叉树
            static void PreOrder<T>(nodes<T> rootNode)
            {
                if (rootNode != null)
                {
                    Console.WriteLine(rootNode.Data);
                    PreOrder<T>(rootNode.LNode);
                    PreOrder<T>(rootNode.RNode);

                }
            }
            
            #endregion

            构造一棵已知的二叉树#region 构造一棵已知的二叉树

            static nodes<string> BinTree()
            {
                nodes<string>[] binTree = new nodes<string>[8];
                //创建结点
                binTree[0] = new nodes<string>("A");
                binTree[1] = new nodes<string>("B");
                binTree[2] = new nodes<string>("C");
                binTree[3] = new nodes<string>("D");
                binTree[4] = new nodes<string>("E");
                binTree[5] = new nodes<string>("F");
                binTree[6] = new nodes<string>("G");
                binTree[7] = new nodes<string>("H");
                //使用层次遍历二叉树的思想,构造一个已知的二叉树

                binTree[0].LNode = binTree[1];
                binTree[0].RNode = binTree[2];
                binTree[1].RNode = binTree[3];
                binTree[2].LNode = binTree[4];
                binTree[2].RNode = binTree[5];
                binTree[3].LNode = binTree[6];
                binTree[3].RNode = binTree[7];
                //返回二叉树的根结点
                return binTree[0];



            }
            #endregion

            中序遍历二叉树#region 中序遍历二叉树
            static void MidOrder<T>(nodes<T> rootNode)
            {
                if (rootNode != null)
                {
                    MidOrder<T>(rootNode.LNode);
                    Console.WriteLine(rootNode.Data);
                    MidOrder<T>(rootNode.RNode);
                }
            } 
            #endregion
            后序遍历二叉树#region 后序遍历二叉树
            static void AfterOrder<T>(nodes<T> rootNode)
            {
                if (rootNode != null)
                {
                    AfterOrder<T>(rootNode.LNode);
                    AfterOrder<T>(rootNode.RNode);
                    Console.WriteLine(rootNode.Data);
                }

            } 
            #endregion

            层次遍历二叉树#region 层次遍历二叉树
            static void LayerOrder<T>(nodes<T> rootNode)
            {
                nodes<T>[] Nodes = new nodes<T>[20];
                int front = -1;
                int rear = -1;
                if (rootNode != null)
                {
                    rear++;
                    Nodes[rear] = rootNode;

                }

                while (front != rear)
                {
                    front++;
                    rootNode = Nodes[front];
                    Console.WriteLine(rootNode.Data);
                    if (rootNode.LNode != null)
                    {
                        rear++;
                        Nodes[rear] = rootNode.LNode;
                    }
                    if (rootNode.RNode != null)
                    {
                        rear++;
                        Nodes[rear] = rootNode.RNode;
                    }
                }
            }
            
            #endregion

            测试的主方法#region 测试的主方法
            static void Main(string[] args)
            {
                nodes<string> rootNode = BinTree();

                Console.WriteLine("先序遍历方法遍历二叉树:");
                PreOrder<string>(rootNode);
               
                Console.WriteLine("中序遍历方法遍历二叉树:");
                MidOrder<string>(rootNode);
                
                Console.WriteLine("后序遍历方法遍历二叉树:");
                AfterOrder<string>(rootNode);


                Console.WriteLine("层次遍历方法遍历二叉树:");
                LayerOrder<string>(rootNode);


                Console.Read();

            } 
            #endregion
        }
    }



    推荐看另一篇随笔:线索二叉树(C# 2.0)
    http://www.cnblogs.com/xuanfeng/archive/2006/09/29/518493.html

  • 相关阅读:
    快速排序(java实现)
    java8 stream一些知识
    Lombok安装、简单使用、入门
    explain mysql 结果分析
    MySQL调优三部曲(二)EXPLAIN
    MySQL调优三部曲(一)慢查询
    排查问题
    Dynamics 365 获取值 设置值
    MySql CP 表 和 数据
    Dynamics 365单项选项集&多项选项集
  • 原文地址:https://www.cnblogs.com/freeliver54/p/2879692.html
Copyright © 2011-2022 走看看