-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathdequeimplementation.cpp
More file actions
162 lines (145 loc) · 3.84 KB
/
dequeimplementation.cpp
File metadata and controls
162 lines (145 loc) · 3.84 KB
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
class Deque
{ int *arr;
int size;
int front,rear;
public:
// Initialize your data structure.
Deque(int n)
{
// Write your code here.
size=n;
front=rear=-1;
arr=new int[size];
}
// Pushes 'X' in the front of the deque. Returns true if it gets pushed into the deque, and false otherwise.
bool pushFront(int x)
{
// Write your code here.
//from front
//check full or not
if( isFull() ) {
return false;
}
else if(isEmpty()) {
front = rear = 0; //front=-1;
}
else if(front == 0 && rear != size-1) {
front = size-1; //front travels piche se from starting index to last one
}
else
{
front--;
}
arr[front] = x;
return true;
}
// Pushes 'X' in the back of the deque. Returns true if it gets pushed into the deque, and false otherwise.
bool pushRear(int x)
{
// Write your code here.
//from rear
if(isFull())
{
return false;
}
else if(isEmpty())
{
front=rear=0;
}
else if(rear == size-1 && front != 0) {
//front is in middle kahi par and rear reached last index
rear = 0; //circular queue
}
else
{
rear++;
}
arr[rear] = x;
return true;
}
// Pops an element from the front of the deque. Returns -1 if the deque is empty, otherwise returns the popped element.
int popFront()
{
// Write your code here.
if(isEmpty()){//to check queue is empty
//cout << "Queue is Empty " << endl;
return -1;
}
int ans = arr[front];
arr[front] = -1;
if(front == rear) { //single element is present
front = rear = -1;
}
else if(front == size - 1) {
front = 0; //to maintain cyclic nature backwards
}
else
{//normal flow
front++; //pop form agge se
}
return ans;
}
// Pops an element from the back of the deque. Returns -1 if the deque is empty, otherwise returns the popped element.
int popRear()
{
// Write your code here.
if(isEmpty()){//to check queue is empty
//cout << "Queue is Empty " << endl;
return -1;
}
int ans = arr[rear];
arr[rear] = -1;
if(front == rear) { //single element is present
front = rear = -1;
}
else if(rear == 0) {
rear = size-1; //to maintain cyclic nature point backwards
}
else
{//normal flow
rear--; //piche se
}
return ans;
}
// Returns the first element of the deque. If the deque is empty, it returns -1.
int getFront()
{
// Write your code here.
if(isEmpty()){
return -1;
}
return arr[front];
}
// Returns the last element of the deque. If the deque is empty, it returns -1.
int getRear()
{
// Write your code here.
if(isEmpty()){
return -1;
}
return arr[rear];
}
// Returns true if the deque is empty. Otherwise returns false.
bool isEmpty()
{
// Write your code here.
if(front==-1)
return true;
else
return false;
}
// Returns true if the deque is full. Otherwise returns false.
bool isFull()
{
// Write your code here.
//check if queue is full or not
if((front==0 && rear==size-1)||(front!=0 && rear==(front-1)%(size-1)))
{
return true;
}
else
{
return false;
}
}
};