数据结构习题及答案

源代码在线查看: 6.46.c

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

相关代码

				6.46③  编写复制一棵二叉树的非递归算法。
				
				要求实现下列函数:
				void CopyBiTree(BiTree T, BiTree &TT);
				/* 基于层次遍历的非递归复制二叉链表 */
				
				二叉链表类型定义:
				typedef char TElemType;   // 设二叉树的元素为char类型
				typedef struct BiTNode {
				    TElemType data;
				    BiTNode  *lchild, *rchild;
				} BiTNode, *BiTree;
				
				可用队列类型Queue的相关定义:
				typedef BiTree QElemType; // 设队列元素为二叉树的指针类型
				Status InitQueue(Queue &Q);
				Status EnQueue(Queue &Q, QElemType e);
				Status DeQueue(Queue &Q, QElemType &e);
				Status GetHead(Queue Q, QElemType &e);
				Status QueueEmpty(Queue Q);
				void CopyBiTree(BiTree T, BiTree &TT)
				/* 基于层次遍历的非递归复制二叉链表 */
				{
				  Queue Q1,Q2;
				  struct BiTNode *p,*q;
				  InitQueue(Q1);InitQueue(Q2);
				  if(T){
				      EnQueue(Q1,T);
				      TT=(BiTNode*)malloc(sizeof(BiTNode));
				      EnQueue(Q2,TT);
				      while(!QueueEmpty(Q1))
				        {
				         DeQueue(Q1,p);
				         DeQueue(Q2,q);
				         q->data=p->data;     
				         if(p->lchild)
				           {q->lchild=(BiTNode*)malloc(sizeof(BiTNode));
				            EnQueue(Q1,p->lchild);         
				            EnQueue(Q2,q->lchild);
				            }
				         if(p->rchild)
				           {q->rchild=(BiTNode*)malloc(sizeof(BiTNode));     
				            EnQueue(Q1,p->rchild);
				            EnQueue(Q2,q->rchild);
				           }
				      } //while
				  }//if
				}
							

相关资源