-
Notifications
You must be signed in to change notification settings - Fork 1k
/
Copy pathpostorder_Traversal.java
144 lines (134 loc) · 3.22 KB
/
postorder_Traversal.java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
import java.util.*;
class node{
int value;
node left;
node right;
node(int key)
{
value = key;
left = null;
right = null;
}
node(int key, node left, node right )
{
this.value = key;
this.left = left;
this.right = right;
}
}
class stack
{
node[] array = new node[10000];
private int top;
stack()
{
top = 0;
}
void push(node item)
{
array[++top] = item;
}
node pop()
{
int temp = top;
--top;
return array[temp];
}
boolean isEmpty()
{
if(top == 0)
return true;
else
return false;
}
}
public class postorder_Traversal {
node root;
void postorder_traversal_Iterative()
{
stack stack1 = new stack();
stack stack2 = new stack();
if(root == null)
return;
stack1.push(root);
while(!stack1.isEmpty())
{
node item = stack1.pop();
stack2.push(item);
if(item.left!=null)
{
stack1.push(item.left);
}
if(item.right!=null)
{
stack1.push(item.right);
}
}
while(!stack2.isEmpty())
{
node item = stack2.pop();
System.out.print(item.value+" ");
}
System.out.print("\n");
}
public void postorderRecursive(node root)
{
if(root == null)
return;
postorderRecursive(root.left);
postorderRecursive(root.right);
System.out.print(root.value + " ");
}
void postorder_traversal_recursive()
{
postorderRecursive(root);
}
public postorder_Traversal(){
root=takeInput(null,false);
}
node takeInput(node parent,Boolean isleftorright){
Scanner s = new Scanner(System.in);
if(parent==null){
System.out.println("Enter the value of root node");
}
else {
if(isleftorright){
System.out.println("enter the value of left child of "+parent.value);
}
else {
System.out.println("enter the value of right child "+parent.value);
}
}
int value=s.nextInt();
node node=new node(value,null,null);
boolean choice;
System.out.println("Do you have left child of "+node.value);
choice=s.nextBoolean();
if(choice){
node.left=takeInput(node,true);
}
System.out.println("Do you have right child of "+node.value);
choice=s.nextBoolean();
if(choice){
node.right=takeInput(node,false);
}
return node;
}
public static void main(String args[])
{
postorder_Traversal binaryTree = new postorder_Traversal();
binaryTree.postorder_traversal_Iterative();
binaryTree.postorder_traversal_recursive();
}
}
/* for this tree
1
/ \
2 3
/ \ / \
4 5 6 7
/ \ / \
null null null null
post orde traversal of above tree is
4 5 2 6 7 3 1
*/