-
Notifications
You must be signed in to change notification settings - Fork 506
/
Copy pathSort a stack.cpp
50 lines (42 loc) · 1.17 KB
/
Sort a 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
/*
Sort a stack
============
Given a stack, the task is to sort it such that the top of the stack has the greatest element.
Example 1:
Input:
Stack: 3 2 1
Output: 3 2 1
Example 2:
Input:
Stack: 11 2 32 3 41
Output: 41 32 11 3 2
Your Task:
You don't have to read input or print anything. Your task is to complete the function sort() which sorts the elements present in the given stack. (The sorted stack is printed by the driver's code by popping the elements of the stack.)
Expected Time Complexity : O(N*N)
Expected Auixilliary Space : O(N) recursive.
Constraints:
1<=N<=100
Note:The Input/Ouput format and Example given are used for system's internal purpose, and should be used by a user for Expected Output only. As it is a function problem, hence a user should not read any input from stdin/console. The task is to complete the function specified, and not to write the full code.
*/
void insert(stack<int> &s, int t)
{
if (s.size() == 0 || s.top() < t)
s.push(t);
else
{
int temp = s.top();
s.pop();
insert(s, t);
s.push(temp);
}
}
void SortedStack ::sort()
{
if (s.size() > 0)
{
int temp = s.top();
s.pop();
sort();
insert(s, temp);
}
}