-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathDemo1.java
92 lines (77 loc) · 1.67 KB
/
Demo1.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
/*
Copyright (C) Deepali Srivastava - All Rights Reserved
This code is part of DSA course available on CourseGalaxy.com
*/
package heap;
public class Demo1
{
public static void buildHeap_TopDown(int[] a, int n)
{
for(int i=2; i<=n; i++)
restoreUp(i,a);
}
public static void buildHeap_BottomUp(int[] a, int n)
{
for(int i=n/2; i>=1; i--)
restoreDown(i,a,n);
}
private static void restoreUp(int i, int[] a)
{
int k=a[i];
int iparent=i/2;
while(a[iparent]<k) /* No sentinel : while(iparent>=1 && a[iparent]<k) */
{
a[i]=a[iparent];
i=iparent;
iparent=i/2;
}
a[i]=k;
}
private static void restoreDown(int i, int[] a, int n)
{
int k=a[i];
int lchild=2*i, rchild=lchild+1;
while(rchild<=n)
{
if( k>=a[lchild] && k>=a[rchild] )
{
a[i]=k;
return;
}
else if(a[lchild] > a[rchild])
{
a[i]=a[lchild];
i=lchild;
}
else
{
a[i]=a[rchild];
i=rchild;
}
lchild=2*i;
rchild=lchild+1;
}
/*If number of nodes is even*/
if(lchild==n && k<a[lchild])
{
a[i]=a[lchild];
i=lchild;
}
a[i]=k;
}
public static void main(String[] args)
{
int a1[] = {99999,1,4,5,7,9,10};
int n1=a1.length-1;
buildHeap_BottomUp(a1,n1);
for(int i=1; i<=n1; i++ )
System.out.print(a1[i] + " ");
System.out.println();
int a2[] = {99999,1,4,5,7,9,10};
int n2=a2.length-1;
buildHeap_TopDown(a2,n2);
for(int i=1; i<=n2; i++ )
System.out.print(a2[i] + " ");
System.out.println();
}
}