C/C++二叉树的便利

输入:
    第一行输入结点的个数。接下里n行按照下述格式输入各结点的信息,每个结点占一行。
    id left right
    id为结点编号,left为左子结点编号,right为右子结点编号。不存在子结点时left(right)为-1

输出:
    第一行输出前序遍历的结点编号
    第二行输出中序遍历结点编号
    第三行输出后序遍历结点编号

在这里插入图片描述

代码

#include<stdio.h>
#define MAX 10000
#define NIL -1

struct Node{
	int p, l, r;
}; 

struct Node T[MAX];
int n;

void preParse(int u){
	if(u == NIL) return;
	printf(" %d", u);
	preParse(T[u].l);
	preParse(T[u].r);
}

void inParse(int u){
	if(u == NIL) return;
	inParse(T[u].l);
	printf(" %d", u);
	inParse(T[u].r); 
}

void postParse(int u){
	if(u == NIL) return;
	postParse(T[u].l);
	postParse(T[u].r);
	printf(" %d", u);
}

int main(){
	int i, v, l, r, root;
	
	scanf("%d", &n);
	for(i = 0; i < n; i++){
		T[i].p = NIL;
	}
	
	for(i = 0; i < n; i++){
		scanf("%d %d %d", &v, &l, &r);
		T[v].l = l;
		T[v].r = r;
		if(l != NIL) T[l].p = v;
		if(r != NIL) T[r].p = v;
	}
	
	for(i = 0; i < n; i++) if(T[i].p == NIL) root = i;
	
	printf("Preorder\n");
	preParse(root);
	printf("\n");
	printf("Inorder\n");
	inParse(root);
	printf("\n");
	printf("Postorder\n");
	postParse(root);
	printf("\n");
	
	return 0;
}
发布了54 篇原创文章 · 获赞 17 · 访问量 9161

猜你喜欢

转载自blog.csdn.net/qq_41979513/article/details/103694880