-
Notifications
You must be signed in to change notification settings - Fork 1.1k
/
minHeap.c
192 lines (174 loc) · 4.83 KB
/
minHeap.c
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
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
/*
A min heap has the property that the parent is less than or equal to the child nodes.
When using a 0-indexed array,
Left child of a node at i is (2 * i + 1)
Right child of a node at i is (2 * i + 2)
Parent is (i - 1) / 2
*/
#include <stdio.h>
#include <stdlib.h>
typedef struct heap{
int currentSize, capacity;
int *arr;
}heap;
heap * createHeap(int capacity) {
heap *h = (heap *)malloc(sizeof(heap));
h -> arr = (int *)malloc(capacity * sizeof(int));
h -> currentSize = -1;
h -> capacity = capacity;
return h;
}
/* to initialize an empty heap of a given capacity */
void search(heap *h, int key) {
int index;
for (index = 0; index <= h -> currentSize; index ++) {
if (h -> arr[index] == key) {
printf("Found at position %d!\n", index + 1);
return;
}
}
printf("Not found!\n");
}
/* to search if a given element is present in the heap or not */
void swap(int arr[10], int index1, int index2) {
int temp = arr[index1];
arr[index1] = arr[index2];
arr[index2] = temp;
}
/* to swap elements at two positions of an array */
void upHeapify(heap *h, int index) {
int parent = (index - 1) / 2;
if (h -> arr[parent] > h -> arr[index]) {
swap(h -> arr, parent, index);
upHeapify(h, parent);
}
}
/* moving an element up the heap to satisfy the min heap property */
void insert(heap *h, int value) {
if (h -> currentSize == h -> capacity - 1) {
printf("Heap is full. Cannot insert\n");
return;
}
h -> arr[ ++ h -> currentSize] = value;
upHeapify(h, h -> currentSize);
printf("Inserted!\n");
}
/* inserting an element into the heap */
void downHeapify(heap *h, int index) {
int lChild = 2 * index + 1, rChild = 2 * index + 2, smallest = index;
if (lChild <= h -> currentSize && h -> arr[lChild] < h -> arr[smallest])
smallest = lChild;
if (rChild <= h -> currentSize && h -> arr[rChild] < h -> arr[smallest])
smallest = rChild;
if (smallest != index) {
swap(h -> arr, smallest, index);
downHeapify(h, smallest);
}
}
/* moving an element down the heap to satisfy the min heap property */
void extract(heap *h) {
if (h -> currentSize < 0) {
printf("Heap is empty. Cannot extract!\n");
return;
}
int root = h -> arr[0];
h -> arr[0] = h -> arr[h -> currentSize --];
downHeapify(h, 0);
printf("Extracted number is %d!\n", root);
}
/* to extract the minimum element(i.e the root) of the min heap */
void insertExtract(heap *h, int value) {
if (h -> currentSize < 0 || value < h -> arr[0]) {
printf("Extracted number is %d!\n", value);
return;
}
printf("Extracted number is %d!\n", h -> arr[0]);
h -> arr[0] = value;
downHeapify(h, 0);
}
/* to insert an element into the heap and then extract the minimum element */
void display(heap *h) {
for (int index = 0; index <= h -> currentSize; index ++) {
printf("%d ", h -> arr[index]);
}
printf("\n");
}
/* to display the min heap */
int main() {
int choice, capacity;
printf("Enter capacity of minHeap:\n");
scanf("%d", &capacity);
heap *h = createHeap(capacity);
do {
printf("1. Insert\n2. Extract\n3. Insert and Extract\n4. Display\n5. Search\n6. Exit\nEnter your choice:\n");
scanf("%d", &choice);
switch (choice) {
case 1: {
int num;
printf("Enter number to be inserted:\n");
scanf("%d", &num);
insert(h, num);
break;
}
case 2: {
extract(h);
break;
}
case 3: {
int num;
printf("Enter number to be inserted:\n");
scanf("%d", &num);
insertExtract(h, num);
break;
}
case 4: {
printf("The minHeap is:\n");
display(h);
break;
}
case 5: {
int num;
printf("Enter the number to be searched:\n");
scanf("%d", &num);
search(h, num);
break;
}
case 6: {
printf("Exiting\n");
break;
}
default: {
printf("Invalid choice. Exiting\n");
break;
}
}
} while( choice > 0 && choice <= 5);
}
/*
Sample I/O:
capacity of minHeap: 10
insert 5
display: 5
insert 3
display: 3 5
insert 2
display: 2 5 3
extract: 2
display: 3 5
search 2: Not found
insert and extract 2: 2
display: 3 5
exit
Time Complexities:
insert - O(log(n))
extract - O(log(n))
insert extract - O(log(n))
display - O(n)
search - O(n)
Space Complexities:
insert - O(1)
extract - O(1)
insert extract - O(1)
display - O(1)
search - O(1)
*/