0
点赞
收藏
分享

微信扫一扫

【educoder】数据结构-二叉树及其应用

微言记 2022-05-03 阅读 115
数据结构

目录

第1关:由双遍历序列构造二叉树

第2关:打印二叉树


第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;
}
举报

相关推荐

0 条评论