目录
第1关:由双遍历序列构造二叉树
///
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include "ConstructTree.h"
/
/*
InPreToTree(): 由前序遍历序列和中序遍历序列构造二叉树
前序序列为pa[p1:p2]
中序序列为ia[i1:i2]
返回所构造的二叉树的根指针
*/
TNode* InPreToTree(char *pa, char *ia, int p1, int p2, int i1, int i2)
{
/*请在BEGIN和END之间实现你的代码*/
/*****BEGIN*****/
TNode *root=new TNode;
root->data=pa[p1];
root->left=NULL;
root->right=NULL;
int i;
for(i=i1;i<=i2;i++)
{
if(ia[i]==pa[p1])
{
break;
}
}
int llen=i-i1;
if(llen>0)
root->left=InPreToTree(pa,ia,p1+1,p1+llen,i1,i-1);
int rlen=i2-i;
if(rlen>0)
root->right=InPreToTree(pa,ia,p2-rlen+1,p2,i+1,i2);
return root;
/******END******/
/*请不要修改[BEGIN,END]区域外的代码*/
}
void PrintPostTravel(TNode* t)
{
if(t==NULL) return;
if(t->left) PrintPostTravel(t->left);
if(t->right) PrintPostTravel(t->right);
printf("%c", t->data);
}
void DeleteTree(TNode* t)
{
if(t==NULL) return;
if(t->left) DeleteTree(t->left);
if(t->right) DeleteTree(t->right);
delete t;
}
第2关:打印二叉树
///
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include "PrintTree.h"
/
/*=================================================
函数:TNode* LayersToTree(char *A, int n)
功能:由补充虚结点(‘^’)的层序序列构造二叉树
参数:A: 补充了虚结点(‘^’)的层序序列
n: 序列的长度
输出: 所构造的二叉树的根指针,NULL表示没有构造出二叉树
==================================================*/
TNode* LayersToTree(char *A, int n)
{
TNode** pnode;
TNode* node;
int i;
if(n<=0)
return NULL;
pnode= new TNode*[n];
for(i=0; i<n; i++){
if(A[i]!='^'){
node=new TNode;
node->data=A[i];
node->left=NULL;
node->right=NULL;
pnode[i]=node;
}
else
pnode[i]=NULL;
}
for(i=0; i<n; i++){
if(pnode[i]==NULL) continue;
if(2*(i+1)<=n && pnode[2*(i+1)-1]!=NULL)
pnode[i]->left=pnode[2*(i+1)-1];
if(2*(i+1)+1<=n && pnode[2*(i+1)]!=NULL)
pnode[i]->right=pnode[2*(i+1)];
}
node=pnode[0];
delete pnode;
return node;
}
void PrintTreeRootLeft(TNode* r, int layer)
//r是树中一棵子树的根,打印以结点r为根的子树,
//layer是r在树中所处的层,约定树的根结点的层号为1
{
/*请在BEGIN和END之间实现你的代码*/
/*****BEGIN*****/
if(r==NULL) return;
PrintTreeRootLeft(r->right,layer+1);
for(int i=1;i<layer;i++)
{
printf("-----");
}
printf("----%c\n",r->data);
PrintTreeRootLeft(r->left,layer+1);
/******END******/
/*请不要修改[BEGIN,END]区域外的代码*/
}
void DeleteTree(TNode* t)
{
if(t==NULL) return;
if(t->left) DeleteTree(t->left);
if(t->right) DeleteTree(t->right);
delete t;
}