forked from Sam-Si/DataStructures-Algorithms
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Special Stack.cpp
69 lines (59 loc) · 1.89 KB
/
Special Stack.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
63
64
65
66
67
68
69
/*
Special Stack
=============
Design a data-structure SpecialStack that supports all the stack operations like push(), pop(), isEmpty(), isFull() and an additional operation getMin() which should return minimum element from the SpecialStack. Your task is to complete all the functions, using stack data-Structure.
Example 1:
Input:
Stack: 18 19 29 15 16
Output: 15
Explanation:
The minimum element of the stack is 15.
Your Task:
Since this is a function problem, you don't need to take inputs. You just have to complete 5 functions, push() which takes the stack and an integer x as input and pushes it into the stack; pop() which takes the stack as input and pops out the topmost element from the stack; isEmpty() which takes the stack as input and returns true/false depending upon whether the stack is empty or not; isFull() which takes the stack and the size of the stack as input and returns true/false depending upon whether the stack is full or not (depending upon the
given size); getMin() which takes the stack as input and returns the minimum element of the stack.
Note: The output of the code will be the value returned by getMin() function.
Expected Time Complexity: O(N) for getMin, O(1) for remaining all 4 functions.
Expected Auxiliary Space: O(1) for all the 5 functions.
Constraints:
1 ≤ N ≤ 104
*/
void push(stack<int> &s, int a)
{
// Your code goes here
s.push(a);
}
bool isFull(stack<int> &s, int n)
{
// Your code goes here
return s.size() == n;
}
bool isEmpty(stack<int> &s)
{
// Your code goes here
return s.size() == 0;
}
int pop(stack<int> &s)
{
// Your code goes here
int ans = s.top();
s.pop();
return ans;
}
int getMin(stack<int> &s)
{
// Your code goes here
stack<int> temp;
int mi = s.top();
while (s.size())
{
mi = min(mi, s.top());
temp.push(s.top());
s.pop();
}
while (temp.size())
{
s.push(temp.top());
temp.pop();
}
return mi;
}