Skip to content

Commit

Permalink
Merge pull request #1749 from DinkyRajpoot56/main
Browse files Browse the repository at this point in the history
Merged Two Sorted Arrays Using Circular Queue
  • Loading branch information
pankaj-bind authored Nov 8, 2024
2 parents f1837ce + 9538eca commit 66d5d46
Show file tree
Hide file tree
Showing 2 changed files with 145 additions and 0 deletions.
Original file line number Diff line number Diff line change
@@ -0,0 +1,131 @@
#include <stdio.h>
#include <stdbool.h>

#define SIZE 100 // Adjust this size as needed

typedef struct
{
int arr[SIZE];
int front;
int rear;
int capacity;
} CircularQueue;

// Function to initialize the queue
void initializeQueue(CircularQueue *queue, int capacity)
{
queue->front = -1;
queue->rear = -1;
queue->capacity = capacity;
}

// Function to check if the queue is full
bool isFull(CircularQueue *queue)
{
return ((queue->rear + 1) % queue->capacity == queue->front);
}

// Function to check if the queue is empty
bool isEmpty(CircularQueue *queue)
{
return (queue->front == -1);
}

// Function to enqueue an element into the queue
void enqueue(CircularQueue *queue, int value)
{
if (isFull(queue))
{
printf("Queue is full\n");
return;
}
if (isEmpty(queue))
{
queue->front = 0;
}
queue->rear = (queue->rear + 1) % queue->capacity;
queue->arr[queue->rear] = value;
}

// Function to dequeue an element from the queue
int dequeue(CircularQueue *queue)
{
if (isEmpty(queue))
{
printf("Queue is empty\n");
return -1;
}
int value = queue->arr[queue->front];
if (queue->front == queue->rear)
{
queue->front = -1; // Queue is now empty
queue->rear = -1;
}
else
{
queue->front = (queue->front + 1) % queue->capacity;
}
return value;
}

// Function to display the queue
void displayQueue(CircularQueue *queue)
{
if (isEmpty(queue))
{
printf("Queue is empty\n");
return;
}
int i = queue->front;
printf("Queue elements are: ");
while (i != queue->rear)
{
printf("%d ", queue->arr[i]);
i = (i + 1) % queue->capacity;
}
printf("%d\n", queue->arr[queue->rear]);
}

// Function to merge two sorted arrays using the circular queue
void mergeSortedArrays(int arr1[], int size1, int arr2[], int size2, CircularQueue *queue)
{
int i = 0, j = 0;
while (i < size1 && j < size2)
{
if (arr1[i] < arr2[j])
{
enqueue(queue, arr1[i++]);
}
else
{
enqueue(queue, arr2[j++]);
}
}
// Enqueue any remaining elements from arr1
while (i < size1)
{
enqueue(queue, arr1[i++]);
}
// Enqueue any remaining elements from arr2
while (j < size2)
{
enqueue(queue, arr2[j++]);
}
}

int main()
{
int arr1[] = {1, 3, 5, 7};
int arr2[] = {2, 4, 6, 8};
int size1 = sizeof(arr1) / sizeof(arr1[0]);
int size2 = sizeof(arr2) / sizeof(arr2[0]);

CircularQueue queue;
initializeQueue(&queue, size1 + size2);

mergeSortedArrays(arr1, size1, arr2, size2, &queue);

displayQueue(&queue);

return 0;
}
14 changes: 14 additions & 0 deletions Queue/MergingTwoSortedArraysUsingCircularQueue/README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,14 @@
# Explanation:

CircularQueue Structure: Contains the array, pointers for front and rear, and the capacity.
initializeQueue: Initializes the front and rear pointers to -1 to indicate an empty queue.
isFull and isEmpty: Utility functions to check if the queue is full or empty.
enqueue: Adds an element to the queue and updates the rear pointer.
dequeue: Removes an element from the queue and updates the front pointer.
mergeSortedArrays: Merges the two sorted arrays and enqueues elements in sorted order into the queue.
main: Initializes the arrays and calls the merge function, displaying the merged queue.

# Key Points:

The queue size must be large enough to hold all elements from both arrays.
This code assumes no overflow handling beyond basic checks. For larger arrays, increase SIZE or use dynamic memory.

0 comments on commit 66d5d46

Please sign in to comment.