二叉树的应用

1.树的遍历

详情:
给定一棵二叉树的后序遍历和中序遍历,请你输出其层序遍历的序列。这里假设键值都是互不相等的正整数。

输入格式:
输入第一行给出一个正整数N(≤30),是二叉树中结点的个数。第二行给出其后序遍历序列。第三行给出其中序遍历序列。数字间以空格分隔。

输出格式:
在一行中输出该树的层序遍历的序列。数字间以1个空格分隔,行首尾不得有多余空格。

输入样例:
7
2 3 1 5 7 6 4
1 2 3 4 5 6 7
输出样例:
4 1 6 3 5 7 2

代码实现:

#include<malloc.h>
#include<stdio.h>
#define MaxSize 100

typedef int ElemType;
typedef struct node
{
    ElemType data;
    struct node *lchild;
    struct node * rchild;
}BTNode;



BTNode* CreateBTree(int *pre, int *in, int n)   // 根据后序和中序遍历序列确定树的结构
{
    int k;   // 记录根节点左子树的个数
    int *p;  // 指向根节点
    if (n <= 0)
        return NULL;
    BTNode *b = (BTNode*)malloc(sizeof(BTNode));
    b->data = *(pre+n-1);  // 树的根节点为后序序列的最后一个编号
    for (p = in; p < in + n; ++p)
        if (*p == *(pre+n-1))  // 在中序序列中寻找根节点的位置
            break;				// 找到后退出循环
    k = p-in;          // 记录根节点左子树节点个数
    b->lchild = CreateBTree(pre, in, k);  // 递归
    b->rchild = CreateBTree(pre+k, p+1, n-k-1);
    return b;
}
typedef struct{
	BTNode*data[MaxSize];
	int count,rear;
}SqQueue;
void InitQueue(SqQueue *&q){
	q=(SqQueue*)malloc(sizeof(SqQueue*));
	q->count=0;
	q->rear=0;
}
void Destroy(SqQueue*&q){
	free(q);
}
bool QueueEmpty(SqQueue*q){
	return q->count==0;
}
bool enQueue(SqQueue*&q,BTNode* e){
	if(q->count==MaxSize){
		return false;
	}
	q->rear=(q->rear+1)%MaxSize;
	q->data[q->rear]=e;
	q->count++;
	return true;
}
bool deQueue(SqQueue*&q,BTNode*& e){
	if(q->count==0){
		return false;
	}
	int index=(q->rear-q->count+MaxSize)%MaxSize+1;
	e=q->data[index];
	q->count--;
	return true;
}

void levelOrder(BTNode*b,int a[]){
	BTNode*p;
	SqQueue*qu;
	InitQueue(qu);
	enQueue(qu,b);
	int tt=0;
	while(!QueueEmpty(qu)){
		deQueue(qu,p);
		a[tt++]=p->data;
		//printf("%c",p->data);
		if(p->lchild!=NULL){
			enQueue(qu,p->lchild);
		}
		if(p->rchild!=NULL){
			enQueue(qu,p->rchild);
		}

	}
}

int main()
{
    int n;
    scanf("%d",&n);
    int a[100];
    int post[100],in[100];
    for(int i=0;i<n;i++)
        scanf("%d",&post[i]);
    for(int i=0;i<n;i++)
        scanf("%d",&in[i]);
    BTNode *b;
    b = CreateBTree(post,in,n);
    //TravLevel(b);
    levelOrder(b,a);
    for (int i=0;i<n-1;i++){
        printf("%d ",a[i]);
    }printf("%d",a[n-1]);
    return 0;
}

二叉树的应用

2.列出叶结点

详情:
对于给定的二叉树,本题要求你按从上到下、从左到右的顺序输出其所有叶节点。

输入格式:
首先第一行给出一个正整数 N(≤10),为树中结点总数。树中的结点从 0 到 N−1 编号。随后 N 行,每行给出一个对应结点左右孩子的编号。如果某个孩子不存在,则在对应位置给出 “-”。编号间以 1 个空格分隔。

输出格式:
在一行中按规定顺序输出叶节点的编号。编号间以 1 个空格分隔,行首尾不得有多余空格。

输入样例:

8
1 -
- -
0 -
2 7
- -
- -
5 -
4 6
4 1 5

输出样例:

代码实现:

#include <iostream>  
#include<stdio.h>  
#include<malloc.h>  
#define MaxSize 100  
using namespace std;  
  
  
typedef char ElemType;  
  
typedef struct node  
{  
    ElemType data;  
    struct node *lchild;  
    struct node * rchild;  
}BTNode;  
typedef struct{  
    BTNode*data[MaxSize];  
    int count,rear;  
}SqQueue;  
void InitQueue(SqQueue *&q){  
    q=(SqQueue*)malloc(sizeof(SqQueue*));  
    q->count=0;  
    q->rear=0;  
}  
void Destroy(SqQueue*&q){  
    free(q);  
}  
bool QueueEmpty(SqQueue*q){  
    return q->count==0;  
}  
bool enQueue(SqQueue*&q,BTNode* e){  
    if(q->count==MaxSize){  
        return false;  
    }  
    q->rear=(q->rear+1)%MaxSize;  
    q->data[q->rear]=e;  
    q->count++;  
    return true;  
}  
bool deQueue(SqQueue*&q,BTNode*& e){  
    if(q->count==0){  
        return false;  
    }  
    int index=(q->rear-q->count+MaxSize)%MaxSize+1;  
    e=q->data[index];  
    q->count--;  
    return true;  
}  
void levelOrder(BTNode*b,char cs[]){  
    BTNode*p;  
    SqQueue*qu;  
    InitQueue(qu);  
    enQueue(qu,b);  
    int t=0;  
    while(!QueueEmpty(qu)){  
        deQueue(qu,p);  
        if(p->lchild!=NULL){  
            enQueue(qu,p->lchild);  
        }  
        if(p->rchild!=NULL){  
            enQueue(qu,p->rchild);  
        }  
        if(p->lchild==NULL &&p->rchild==NULL){  
            cs[t]=p->data;  
            t++;  
        }  
  
    }  
    Destroy(qu);  
}  
void PreOrder(BTNode*b){  
    if(b!=NULL){  
        printf("%c ",b->data);  
        PreOrder(b->lchild);  
        PreOrder(b->rchild);  
    }  
}  
void InOrder(BTNode*b){  
    if(b!=NULL){  
  
        InOrder(b->lchild);  
        printf("%c",b->data);  
        InOrder(b->rchild);  
    }  
}  
int func(char c[][2],int n){  
  
    for(int i=0;i<n;i++){  
        bool flag=false;  
  
        for(int j=0;j<n;j++){  
            if(c[j][0]==(char)(i+48)){  
                flag=true;  
                break;  
            }  
            else if(c[j][1]==(char)(i+48)){  
                flag=true;  
                break;  
            }  
  
        }  
  
        if(flag==false){  
            return i;  
        }  
  
    }return -1;  
  
}  
  
void CreateBT(BTNode*b,char c[][2],int root,int &k)  
{  
    if(c[root][0]=='-'&&c[root][1]=='-'){  
        b->lchild=NULL;b->rchild=NULL;  
        k++;  
        return ;  
  
    }  
    if(c[root][0]!='-'){  
        b->lchild=(BTNode*)malloc(sizeof(BTNode));  
        b->lchild->data=c[root][0];  
        CreateBT(b->lchild,c,(int)(c[root][0])-48,k);  
    }else{  
        b->lchild=NULL;  
    }  
    if(c[root][1]!='-'){  
        b->rchild=(BTNode*)malloc(sizeof(BTNode));  
        b->rchild->data=c[root][1];  
        CreateBT(b->rchild,c,(int)(c[root][1])-48,k);  
    }else{  
        b->rchild=NULL;  
    }  
}  
  
int main()  
{  
    BTNode*b;  
    b=(BTNode*)malloc(sizeof(BTNode));  
    int n;cin>>n;  
    char c[n][2];  
    for (int i=0;i<n;i++){  
        cin>>c[i][0]>>c[i][1];  
    }  
    int k;  
    int ff=func(c,n);  
    b->data=(char)(ff+48);  
    CreateBT(b,c,ff,k);  
    char cs[10];  
    levelOrder(b,cs);  
    for(int j=0;j<k-1;j++)  
    {  
        cout<<cs[j]<<" ";  
    }  
    cout<<cs[k-1];  
    return 0;  
}  

二叉树的应用

3.二叉树的遍历

详情:
根据输入构造二叉树,输出该二叉树的先序序列。二叉树共有N个节点,节点编号是1到N。约定1号节点是根节点。

输入格式:
第一行输入整数N。 接下来有N行,依次给出1到N节点的左孩子和右孩子。对于这N行中的每一行,有两个整数。第i(i=1, 2, …, N)行中,第一个整数指出左孩子的编号,第二个整数指出右孩子的编号。如果整数值为0,表示没有左孩子或右孩子。

输出格式:
输出一行,内容是二叉树的先序序列。节点编号之间用空格隔开,行末有1个空格。

输入样例:

6
2 5
3 4
0 0
0 0
0 6
0 0

输出样例:

1 2 3 4 5 6 

代码实现:

#include <iostream>
#include<stdio.h>
#include<malloc.h>
using namespace std;


typedef int ElemType;

typedef struct node
{
    ElemType data;
    struct node *lchild;
    struct node * rchild;
}BTNode;


void CreateBT(BTNode*b,int c[][2],int root)
{
    if(c[root][0]==0&&c[root][1]==0){
        b->lchild=NULL;b->rchild=NULL;

        return ;
    }
    if(c[root][0]!=0){
        b->lchild=(BTNode*)malloc(sizeof(BTNode));
        b->lchild->data=c[root][0];
        CreateBT(b->lchild,c,c[root][0]);
    }else{
    	b->lchild=NULL;
	}
    if(c[root][1]!=0){
        b->rchild=(BTNode*)malloc(sizeof(BTNode));
        b->rchild->data=c[root][1];
        CreateBT(b->rchild,c,c[root][1]);
    }else{
    	b->rchild=NULL;
	}


}

void PreOrder(BTNode *b)
{
    if(b!=NULL)
    {
        cout<<b->data<<" ";
        PreOrder(b->lchild);
        PreOrder(b->rchild);
    }
}
int main()
{
    BTNode*b;
    b=(BTNode*)malloc(sizeof(BTNode));
    b->data=1;
    int n;cin>>n;
    int c[n+1][2];
    for (int i=1;i<n+1;i++){
        cin>>c[i][0]>>c[i][1];
    }

    CreateBT(b,c,1);
    PreOrder(b);
    cout<<endl;
    return 0;
}

二叉树的应用

上一篇:线索二叉树(中序)


下一篇:顺序表中的完全二叉树转存到二叉链表中