-
Notifications
You must be signed in to change notification settings - Fork 508
/
Copy pathStack using two queues.cpp
62 lines (54 loc) · 1.28 KB
/
Stack using two queues.cpp
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
/*
Stack using two queues
======================
Implement a Stack using two queues q1 and q2.
Example 1:
Input:
push(2)
push(3)
pop()
push(4)
pop()
Output: 3 4
Explanation:
push(2) the stack will be {2}
push(3) the stack will be {2 3}
pop() poped element will be 3 the
stack will be {2}
push(4) the stack will be {2 4}
pop() poped element will be 4
Example 2:
Input:
push(2)
pop()
pop()
push(3)
Output: 2 -1
Your Task:
Since this is a function problem, you don't need to take inputs. You are required to complete the two methods push() which takes an integer 'x' as input denoting the element to be pushed into the stack and pop() which returns the integer poped out from the stack(-1 if the stack is empty).
Expected Time Complexity: O(1) for push() and O(N) for pop() (or vice-versa).
Expected Auxiliary Space: O(1) for both push() and pop().
Constraints:
1 <= Number of queries <= 100
1 <= values of the stack <= 100
*/
//Function to push an element into stack using two queues.
void QueueStack ::push(int x)
{
q1.push(x);
}
//Function to pop an element from stack using two queues.
int QueueStack ::pop()
{
if (q1.size() < 1)
return -1;
while (q1.size() > 1)
{
q2.push(q1.front());
q1.pop();
}
int ans = q1.front();
q1.pop();
swap(q1, q2);
return ans;
}