eolymp
bolt
Try our new interface for solving problems
Problems

Post-Order Traversal of a Tree

Post-Order Traversal of a Tree

Given an array of integers. Create a Binary Search Tree from these numbers. If the inserted value equals to the current node, insert it to the right subtree.

Write method PostOrder that makes Post-Order traversal of a tree. In this traversal method the left subtree is visited first, then the right subtree and finally the root node.

prb7463.gif

Write the code according to the next interface:

class TreeNode

{

public:

int val;

TreeNode *left;

TreeNode *right;

TreeNode(int x) : val(x), left(NULL), right(NULL) {}

};

class Tree

{

public:

TreeNode *head;

Tree() : head(NULL) {};

void Insert(int val); // Insert number val to Binary Search Tree

void PostOrder(void); // Print the vertices of a tree according to post-order traversal

};

You can create (use) additional methods if needed.

Input

The first line contains number n (1n100). The second line contains n integers.

Output

Create the Binary Search Tree from input data. Print the vertices of a tree according to post-order traversal.

Time limit 1 second
Memory limit 122.17 MiB
Input example #1
6
14 9 1 14 20 13
Output example #1
1 13 9 20 14 14 
Author Mykhailo Medvediev
Source C++