数据结构习题及答案

源代码在线查看: 6.39.c

软件大小: 52 K
上传用户: GUAIGUAICHENGTI
关键词: 数据结构
下载地址: 免注册下载 普通下载 VIP

相关代码

				6.39④ 假设在二叉链表的结点中增设两个域:双亲
				域(parent)以指示其双亲结点;标志域(mark取值0,
				1或2)以区分在遍历过程中到达该结点时应继续向左
				或向右或访问该结点。 试以此存储结构编写不用栈
				进行后序遍历的递推形式的算法。
				
				要求实现以下函数:
				void PostOrder(BiPTree bt, void (*visit)(TElemType))
				/* 不使用栈,非递归后序遍历二叉树bt,  */
				/* 对每个结点的元素域data调用函数visit */
				
				带双亲指针和标志域的二叉链表类型定义:
				typedef struct BiPTNode {
				  TElemType data;
				  BiTNode  *lchild, *rchild, *parent;
				  int       mark;
				} BiPTNode, *BiPTree;
				void PostOrder(BiPTree bt, void (*visit)(TElemType))
				/* 不使用栈,非递归后序遍历二叉树bt,  */
				/* 对每个结点的元素域data调用函数visit */
				{ BiPTNode *p;  
				  p=bt;
				  while(p)
				    switch(p->mark)
				      {
				      case 0:
				        p->mark=1;
				        if(p->lchild) p=p->lchild; //访问左子树
				        break;
				      case 1:
				        p->mark=2;
				        if(p->rchild) p=p->rchild; //访问右子树
				        break;
				      case 2:
				        visit(p->data);
				        p->mark=0;   //恢复mark值
				        p=p->parent; //返回双亲结点
				     }
				}
				
							

相关资源