Tutorial Sheet 7: - Arjav Kanadia IEC2020101
Tutorial Sheet 7: - Arjav Kanadia IEC2020101
-Arjav Kanadia
IEC2020101
Q1. Insert the following keys in a Priority Queue implemented using a MAX-HEAP
if (largest != index) {
swap(&A[index], &A[largest]);
max_heapify(A, largest);
}
}
int main() {
int A[tree_array_size];
insert(A, 7);
insert(A, 16);
insert(A, 49);
insert(A, 82);
insert(A, 5);
insert(A, 31);
insert(A, 6);
insert(A, 2);
insert(A, 44);
print_heap(A);
printf("%d\n", extract_max(A));
print_heap(A);
printf("%d\n", extract_max(A));
print_heap(A);
printf("%d\n", extract_max(A));
print_heap(A);
printf("%d\n", extract_max(A));
print_heap(A);
printf("%d\n", extract_max(A));
print_heap(A);
printf("%d\n", extract_max(A));
print_heap(A);
return 0;
}
.
#include <stdio.h>
int main()
{
int heap[10], array_size, i, j, c, root, temporary;
printf(" Enter size of array to be sorted :");
scanf("%d", &array_size);
printf(" Enter the elements of array : ");
for (i = 0; i < array_size; i++)
scanf("%d", &heap[i]);
for (i = 1; i < array_size; i++)
{
c = i;
do
{
root = (c - 1) / 2;
if (heap[root] < heap[c])
{
temporary = heap[root];
heap[root] = heap[c];
heap[c] = temporary;
}
c = root;
} while (c != 0);
}
printf("\nHeap array : ");
for (i = 0; i < array_size; i++)
printf("%d\t ", heap[i]);
for (j = array_size - 1; j >= 0; j--)
{
temporary = heap[0];
heap[0] = heap[j] ;
heap[j] = temporary;
root = 0;
do
{
c = 2 * root + 1;
if ((heap[c] < heap[c + 1]) && c < j-1)
c++;
if (heap[root]<heap[c] && c<j)
{
temporary = heap[root];
heap[root] = heap[c];
heap[c] = temporary;
}
root = c;
} while (c < j);
}
printf("\n The sorted array is : ");
for (i = 0; i < array_size; i++)
printf("\t %d", heap[i]);
}
Q3. WAP to generate level order traversal of the binary tree.
Example: for the given binary tree the level order traversal is 1, 2, 3, 4, 5, 6
#include <stdio.h>
#include <stdlib.h>
struct node
int info;
};
struct node *createnode(int key)
newnode->info = key;
newnode->left = NULL;
newnode->right = NULL;
return(newnode);
int max;
if (root!=NULL)
max = leftsubtree + 1;
return max;
else
{
max = rightsubtree + 1;
return max;
if (root != NULL)
if (level == 1)
currentlevel(root->left, level-1);
currentlevel(root->right, level-1);
int main()
{
newnode->left = createnode(2);
newnode->right = createnode(3);
newnode->left->left = createnode(4);
newnode->left->right = createnode(5);
newnode->right->left = createnode(6);
newnode->right->right = createnode(7);
int i;
currentlevel(newnode,i);
return 0;