Title Description

Give you a binary tree and output the tree in the order of traversal.

The first row of the input data is an integer n (1 ≤ n ≤ 1e4), indicating the number of nodes of the tree. Next, there are n-1 rows. Each row has two integers u and V, indicating that there is an edge from node u to node v. input to ensure that the tree takes 1 as the root and u is the parent node of V. For multiple child nodes of a node, the of the child node input earlier is regarded as its left child node.

output data

Output the post order traversal of the tree, and the node numbers are separated by a space.

sample input

6 1 2 2 3 3 4 1 5 5 6

sample output

4 3 2 6 5 1

Example description

The definition of post order traversal is: for each tree accessed, first access its left subtree, then access its right subtree, and finally access the root node.

This topic looks simple, but it really disgusts me. Last semester, it was a 99 data structure. This semester, I practiced a piece and gave it back to the teacher. Now I can't practice how to build a binary tree. This is not the most basic, blue and thin.

But after all, it's homework. You still have to learn now.

But I found a very strange thing in the process of learning binary tree, that is, after defining the structure of nodes, the program does not run when I assign values to the structure. After my repeated attempts, I found happily that I forgot to open space (I want to curse here).

In addition, the way to build a binary tree on this topic is also very strange, so the first thing I thought of at that time was the structure array. In this way, it would be much faster to find nodes according to num, but this idea soon ran aground, because this array is very difficult to open.

Later, Python made a patchwork:

class BiTreeNode: def __init__(self, data): self.data = data self.lchild = None self.rchild = None def post_order(root): if root: post_order(root.lchild) post_order(root.rchild) print(root.data, end=' ') tree=[] up=[] down=[] node=[] n=int(input()) for i in range(n-1): a,b=map(int,input().split()) up.append(a) down.append(b) node.append(a) node.append(b) node=list(set(node)) node=sorted(node) for i in node: tree.append(BiTreeNode(i)) for i in range(n-1): if tree[up[i]].lchild==None: tree[up[i]-1].lchild=tree[down[i]-1] else: tree[up[i]-1].rchild=tree[down[i]-1] post_order(tree[0])

You should also be able to see that it is not smart to put the nodes of the tree into the list. Although the example is correct, it will be sanctioned by OJ immediately.

TLE. . . . (want to curse again)

Python really has a long time problem. It seems that the shortcut is impossible. Just start again and do it honestly in C. However, it's really easy to write a lot after making up the knowledge points. In fact, there are no hard code blocks, but it is torture. So I decided to send it to the Internet to save it to prevent this tragedy from happening again.

#include<stdio.h> #include<iostream> #include<stdlib.h> using namespace std; typedef struct node{ int num; node *left=NULL; node *right=NULL; }node,*tree; void create(tree &T,int a){ T=(node*)malloc(sizeof(node)); T->num=a; T->left=NULL; T->right=NULL; } tree find(tree T,int a) { if(T==NULL){ //printf("error"); return NULL; } if(T->num==a){ return T; } else{ tree mid=find(T->left,a); if(mid!=NULL){ return mid; } else{ return find(T->right,a); } } } void print(tree T){ if(T==NULL){ return; } print(T->left); print(T->right); printf("%d ",T->num); } int main(){ tree T; create(T,1); int n; int a[10003]; int b[10003]; scanf("%d",&n); for(int i=0;i<n-1;i++){ scanf("%d %d",&a[i],&b[i]); tree e=T; tree go=T; go=find(e,a[i]); tree ter; create(ter,b[i]); if(go->left==NULL){ go->left=ter; } else{ go->right=ter; } } print(T); return 0; }