Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Added Double Ended Queue In C #1693

Merged
merged 2 commits into from
Nov 8, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
164 changes: 164 additions & 0 deletions Queue/DoubleEndedQueue/DoubleEndedQueue.c
Original file line number Diff line number Diff line change
@@ -0,0 +1,164 @@
#include <stdio.h>
#include <stdlib.h>

#define MAX 5

int deque[MAX];
int front = -1;
int rear = -1;

int isFull()
{
return ((front == 0 && rear == MAX - 1) || (front == rear + 1));
}

int isEmpty()
{
return (front == -1);
}

void insertFront(int key)
{
if (isFull())
{
printf("Overflow: Unable to insert element at the front. Deque is full.\n");
return;
}

if (front == -1)
{
front = 0;
rear = 0;
}
else if (front == 0)
{
front = MAX - 1;
}
else
{
front = front - 1;
}

deque[front] = key;
printf("Inserted %d at the front.\n", key);
}

void insertRear(int key)
{
if (isFull())
{
printf("Overflow: Unable to insert element at the rear. Deque is full.\n");
return;
}

if (rear == -1)
{
front = 0;
rear = 0;
}
else if (rear == MAX - 1)
{
rear = 0;
}
else
{
rear = rear + 1;
}

deque[rear] = key;
printf("Inserted %d at the rear.\n", key);
}

void deleteFront()
{
if (isEmpty())
{
printf("Underflow: Unable to delete element from the front. Deque is empty.\n");
return;
}

int removed = deque[front];

if (front == rear)
{
front = -1;
rear = -1;
}
else if (front == MAX - 1)
{
front = 0;
}
else
{
front = front + 1;
}

printf("Deleted %d from the front.\n", removed);
}

void deleteRear()
{
if (isEmpty())
{
printf("Underflow: Unable to delete element from the rear. Deque is empty.\n");
return;
}

int removed = deque[rear];

if (front == rear)
{
front = -1;
rear = -1;
}
else if (rear == 0)
{
rear = MAX - 1;
}
else
{
rear = rear - 1;
}

printf("Deleted %d from the rear.\n", removed);
}

void displayDeque()
{
if (isEmpty())
{
printf("Deque is empty.\n");
return;
}

printf("Deque elements are: ");
int i = front;
while (1)
{
printf("%d ", deque[i]);
if (i == rear)
break;
i = (i + 1) % MAX;
}
printf("\n");
}

int main()
{
insertRear(5);
displayDeque();

insertFront(15);
displayDeque();

insertRear(25);
displayDeque();

deleteFront();
displayDeque();

deleteRear();
displayDeque();

return 0;
}
65 changes: 65 additions & 0 deletions Queue/DoubleEndedQueue/README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,65 @@
# Operations on a Double Ended Queue

Below is the circular array implementation of Double Ended Queue. In a circular array, if the array is full, we start from the beginning.

But in a linear array implementation, if the array is full, no more elements can be inserted. In each of the operations below, if the array is full, "overflow message" is thrown.

Before performing the following operations, these steps are followed.

Take an array (Double Ended Queue) of size n.
Set two pointers front = -1 and rear = 0.

# Types of Double Ended Queue

Input Restricted Double Ended Queue
In this Double Ended Queue, input is restricted at a single end but allows deletion at both the ends.
Output Restricted Double Ended Queue
In this Double Ended Queue, output is restricted at a single end but allows insertion at both the ends.

# Insertion at Front in Double Ended Queue in C

To insert an element at the front end of the Double Ended Queue first, check if the Double Ended Queue is full or not if Double Ended Queue is not full then follow the below approach:

Insert At Front in Double Ended Queue-(1)
Insert at front in Double Ended Queue
Approach:

First, check the position of the front in our array.
If front < 1 , reinitialize front as the last index of the array i.e. front = N-1.
Then, add new element to array[front].

# Insertion at Rear in Double Ended Queue in C

Insert At Rear in Double Ended Queue-(1)
Insert at Rear in Double Ended Queue
To insert an element at the rear end of the Double Ended Queue, follow the below approach:

Approach:

First, check if the Double Ended Queue is full or not.
If the Double Ended Queue is full , reinitialize rear with 0 (rear = 0) else increase rear by 1.
Then, add the element to array[rear].

# Deletion at Front in Double Ended Queue in C

To delete an element at the front end of Double Ended Queue the first, follow the below approach:

Approach:

First, check if Double Ended Queue is empty or not.
If the Double Ended Queue is empty (front == -1), then we cannot perform deletion operation. In this condition, we will simply print underflow.
If contains only 1 element (front = rear) , then only one deletion operation can be performed. set front = -1 and rear = -1.
Else if the front is at the last index ( front == n-1 ) , set front at starting index of Double Ended Queue (front = 0).
If none of the above case exists, just increment front by 1 (front = front + 1).

# Deletion at Rear in Double Ended Queue in C

DeletionAtRear
Delete at Rear in Double Ended Queue
To delete an element at the rear end of the Double Ended Queue, follow the below approach:

First, check if the Double Ended Queue is empty or not.
If the Double Ended Queue is empty (front = -1), then deletion operation cannot be performed and we will print underflow.
If the Double Ended Queue has only 1 element( front==rear), we will set front = -1 and rear =-1.
If the rear is at the starting index of Double Ended Queue (rear == 0) , then set rear to last index (rear = n-1).
If none of the above case exists, just decrement rear by 1 (rear = rear-1).
Loading