C#二叉树遍历算法实现浅析 - Go语言中文社区

C#二叉树遍历算法实现浅析


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

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

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

◆C#二叉树遍历算法之先序遍历:

1.访问根结点

2.按先序遍历左子树;

3.按先序遍历右子树;

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

◆C#二叉树遍历算法之中序遍历:

1.按中序遍历左子树;

2.访问根结点;

3.按中序遍历右子树;

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

◆C#二叉树遍历算法之后序遍历:

1.按后序遍历左子树;

2.按后序遍历右子树;

3.访问根结点;

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

◆C#二叉树遍历算法之层次遍历:

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

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

以下是整个二叉遍历算法解决方案的代码:

  1. using System;  
  2. using System.Collections.Generic;  
  3. using System.Text;  
  4.  
  5. namespace structure  
  6. {  
  7.     class Program  
  8.     {  
  9.         #region 二叉树结点数据结构的定义   
  10.         //二叉树结点数据结构包括数据域,左右结点以及父结点成员;  
  11.       class nodesT  
  12.         {  
  13.             T data;  
  14.             nodesT Lnode, Rnode, Pnode;  
  15.             public T Data  
  16.             {  
  17.                 set { data = value; }  
  18.                 get { return data; }  
  19.  
  20.             }  
  21.             public nodesT LNode  
  22.             {  
  23.                 set { Lnode = value; }  
  24.                 get { return Lnode; }  
  25.             }  
  26.             public nodesT RNode  
  27.             {  
  28.                 set { Rnode = value; }  
  29.                 get { return Rnode; }  
  30.  
  31.             }  
  32.  
  33.             public nodesT PNode  
  34.             {  
  35.                 set { Pnode = value; }  
  36.                 get { return Pnode; }  
  37.  
  38.             }  
  39.           public nodes()  
  40.           { }  
  41.           public nodes(T data)  
  42.           {  
  43.               this.data = data;  
  44.           }  
  45.  
  46.         }   
  47.         #endregion  
  48.  
  49.         #region 先序编历二叉树  
  50.         static void PreOrderT(nodesT rootNode)  
  51.         {  
  52.             if (rootNode != null)  
  53.             {  
  54.                 Console.WriteLine(rootNode.Data);  
  55.                 PreOrderT(rootNode.LNode);  
  56.                 PreOrderT(rootNode.RNode);  
  57.  
  58.             }  
  59.         }  
  60.           
  61.         #endregion  
  62.  
  63.         #region 构造一棵已知的二叉树  
  64.  
  65.         static nodesstring BinTree()  
  66.         {  
  67.             nodesstring[] binTree = new nodesstring[8];  
  68.             //创建结点  
  69.             binTree[0] = new nodesstring("A");  
  70.             binTree[1] = new nodesstring("B");  
  71.             binTree[2] = new nodesstring("C");  
  72.             binTree[3] = new nodesstring("D");  
  73.             binTree[4] = new nodesstring("E");  
  74.             binTree[5] = new nodesstring("F");  
  75.             binTree[6] = new nodesstring("G");  
  76.             binTree[7] = new nodesstring("H");  
  77.             //使用层次遍历二叉树的思想,构造一个已知的二叉树  
  78.  
  79.             binTree[0].LNode = binTree[1];  
  80.             binTree[0].RNode = binTree[2];  
  81.             binTree[1].RNode = binTree[3];  
  82.             binTree[2].LNode = binTree[4];  
  83.             binTree[2].RNode = binTree[5];  
  84.             binTree[3].LNode = binTree[6];  
  85.             binTree[3].RNode = binTree[7];  
  86.             //返回二叉树的根结点  
  87.             return binTree[0];  
  88.  
  89.         }  
  90.         #endregion  
  91.  
  92.         #region 中序遍历二叉树  
  93.         static void MidOrderT(nodesT rootNode)  
  94.         {  
  95.             if (rootNode != null)  
  96.             {  
  97.                 MidOrderT(rootNode.LNode);  
  98.                 Console.WriteLine(rootNode.Data);  
  99.                 MidOrderT(rootNode.RNode);  
  100.             }  
  101.         }   
  102.         #endregion  
  103.         后序遍历二叉树#region 后序遍历二叉树  
  104.         static void AfterOrderT(nodesT rootNode)  
  105.         {  
  106.             if (rootNode != null)  
  107.             {  
  108.                 AfterOrderT(rootNode.LNode);  
  109.                 AfterOrderT(rootNode.RNode);  
  110.                 Console.WriteLine(rootNode.Data);  
  111.             }  
  112.  
  113.         }   
  114.         #endregion  
  115.  
  116.        #region 层次遍历二叉树  
  117.         static void LayerOrderT(nodesT rootNode)  
  118.         {  
  119.             nodesT[] Nodes = new nodesT[20];  
  120.             int front = -1;  
  121.             int rear = -1;  
  122.             if (rootNode != null)  
  123.             {  
  124.                 rear++;  
  125.                 Nodes[rear] = rootNode;  
  126.  
  127.             }  
  128.  
  129.             while (front != rear)  
  130.             {  
  131.                 front++;  
  132.                 rootNode = Nodes[front];  
  133.                 Console.WriteLine(rootNode.Data);  
  134.                 if (rootNode.LNode != null)  
  135.                 {  
  136.                     rear++;  
  137.                     Nodes[rear] = rootNode.LNode;  
  138.                 }  
  139.                 if (rootNode.RNode != null)  
  140.                 {  
  141.                     rear++;  
  142.                     Nodes[rear] = rootNode.RNode;  
  143.                 }  
  144.             }  
  145.         }  
  146.           
  147.         #endregion  
  148.  
  149.       #region 测试的主方法  
  150.         static void Main(string[] args)  
  151.         {  
  152.             nodesstring rootNode = BinTree();  
  153.  
  154.             Console.WriteLine("先序遍历方法遍历二叉树:");  
  155.             PreOrderstring(rootNode);  
  156.              
  157.             Console.WriteLine("中序遍历方法遍历二叉树:");  
  158.             MidOrderstring(rootNode);  
  159.               
  160.             Console.WriteLine("后序遍历方法遍历二叉树:");  
  161.             AfterOrderstring(rootNode);  
  162.  
  163.  
  164.             Console.WriteLine("层次遍历方法遍历二叉树:");  
  165.             LayerOrderstring(rootNode);  
  166.  
  167.  
  168.             Console.Read();  
  169.  
  170.         }   
  171.         #endregion  
  172.     }  

C#二叉树遍历算法实现就向你介绍到这里,希望通过对C#二叉树遍历算法实现的讲解使你对C#算法有了一些认识。

版权声明:本文来源51CTO,感谢博主原创文章,遵循 CC 4.0 by-sa 版权协议,转载请附上原文出处链接和本声明。
原文链接:http://developer.51cto.com/art/200908/143290.htm
站方申明:本站部分内容来自社区用户分享,若涉及侵权,请联系站方删除。
  • 发表于 2021-05-16 19:41:26
  • 阅读 ( 1090 )
  • 分类:算法

0 条评论

请先 登录 后评论

官方社群

GO教程

猜你喜欢