Chinaunix首页 | 论坛 | 博客
  • 博客访问: 3896637
  • 博文数量: 408
  • 博客积分: 10227
  • 博客等级: 上将
  • 技术积分: 9820
  • 用 户 组: 普通用户
  • 注册时间: 2009-04-17 21:48
个人简介

非淡泊无以明志,非宁静无以致远

文章存档

2022年(1)

2021年(1)

2020年(2)

2019年(5)

2018年(4)

2017年(3)

2016年(24)

2015年(8)

2014年(7)

2013年(3)

2012年(1)

2011年(23)

2010年(179)

2009年(147)

分类: C/C++

2010-04-06 20:37:18

对于二叉树来讲最主要、最基本的运算是遍历。

遍历二叉树 是指以一定的次序访问二叉树中的每个结点,并且每个结点仅被访问一次。所谓访问结点是指对结点进行各种操作的简称。例如,查询结点数据域的内容,或输出它的值,或找出结点位置,或是执行对结点的其他操作。遍历二叉树的过程实质是把二叉树的结点进行线性排列的过程。假设遍历二叉树时访问结点的操作就是输出结点数据域的值,那么遍历的结果得到一个线性序列。

 从二叉树的递归定义可知,一棵非空的二叉树由根结点及左、右子树这三个基本部分组成。因此,在任一给定结点上,可以按某种次序执行三个操作:

     (1)访问结点本身(N)

     (2)遍历该结点的左子树(L)

     (3)遍历该结点的右子树(R)

以上三种操作有六种执行次序:

     NLRLNRLRNNRLRNLRLN

注意:

  前三种次序与后三种次序对称,故只讨论先左后右的前三种次序。

 由于被访问的结点必是某子树的根,所以N(Node)L(Left subtlee)R(Right subtree)又可解释为根、根的左子树和根的右子树。NLRLNRLRN分别又称为先根遍历、中根遍历和后根遍历。

(1)先根遍历二叉树:

NLR:先根遍历(PreorderTraversal亦称(先序遍历))

         ——访问结点的操作发生在遍历其左右子树之前。

先根遍历可以递归的描述如下:

   如果根不空 : (1) 访问根结点;

   (2) 按先根次序遍历左子树;

   (3) 按先根次序遍历右子树;

   否则返回。

先根遍历的递归算法如下:

【算法6.2

void BiTree::Preorder(NodeType*p)

{ if(p!=NULL)

 { cout<data<<" ";

  preorder(p->lch);

  preorder(p->rch);

  }

}

 

(2)中根遍历二叉树:

LNR:中序遍历(InorderTraversal)

        ——访问结点的操作发生在遍历其左右子树之中()

中根遍历可以递归的描述如下:

   如果根不空 : (1) 按中根次序遍历左子树;

   (2) 访问根结点;

   (3) 按中根次序遍历右子树;;

   否则返回。

中根遍历的递归算法如下:

【算法6.3

void BiTree::Preorder(NodeType*p)

{if(p!=NULL)

 { preorder(p->lch);

   cout<data<<" ";

   preorder(p->rch);

 }

}

 

(3)后根遍历二叉树:

LRN:后序遍历(PostorderTraversal)

         ——访问结点的操作发生在遍历其左右子树之后。

后根遍历可以递归的描述如下:

如果根不空 : (1) 按后根次序遍历左子树;

   (2) 按后根次序遍历右子树;

   (3) 访问根结点;

   否则返回。

后根遍历的递归算法如下:

【算法6.4

void BiTree::Preorder(NodeType*p)

{ if(p!=NULL)

 { preorder(p->lch);

  preorder(p->rch);

  cout<data<<" ";

  }

}

阅读(2984) | 评论(0) | 转发(0) |
0

上一篇:CPU与控制器

下一篇:类模板与模板类

给主人留下些什么吧!~~