码迷,mamicode.com
首页 > 其他好文 > 详细

二叉树详解

时间:2019-07-05 12:22:36      阅读:145      评论:0      收藏:0      [点我收藏+]

标签:三次   好处   printf   pos   bsp   中序   turn   简洁   print   

二叉树详解:

采用递归的方式进行遍历,这样做的好处时代码十分简洁。

 

顺序存储:数组

 

链表存储:链表

typedef struct bi_t_node{

  telemetype data;

  struct bi_t_node *lchild, *rchild;

}bi_t_node, *bi_tree;

 

前序遍历:第一次到达节点时,自左向右

中序遍历:第二次到达节点时,自左向右

后序遍历:第三次到达节点时,自左向右

层序遍历:自上而下,,自左向右

 

示例:

 1 /* 二叉树前序遍历递归算法 */
 2 void pre_order_traverse(bi_tree t)
 3 {
 4     if(NULL == t)
 5         return;
 6     printf("%c", t->data);
 7 
 8     pre_order_traverse(t->lchild);
 9     pre_order_traverse(t->rchild);
10 }
11 
12 /* 二叉树的中序遍历递归算法 */
13 void in_order_traverse(bi_tree t)
14 {
15     if(NULL == t)
16         return;
17 
18     in_order_traverse(t->lchild);
19     printf("%c", t->data);
20     in_order_traverse(t->rchild);
21 }
22 
23 /* 二叉树的后续遍历递归算法 */
24 void post_order_traverse(bi_tree t)
25 {
26     if(NULL == t)
27         return;
28 
29     post_order_traverse(t->lchild);
30     post_order_traverse(t->rchild);
31     printf("%c", t->data);
32 }

 

二叉树详解

标签:三次   好处   printf   pos   bsp   中序   turn   简洁   print   

原文地址:https://www.cnblogs.com/live-program/p/11136324.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!