-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathSpecialStack.java
83 lines (72 loc) · 1.25 KB
/
SpecialStack.java
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
package Stack;
import java.util.Stack;
public class SpecialStack {
static Stack<Integer> st=new Stack<>();
static Stack<Integer> aux=new Stack<>();
static int min;
public static void main(String[] args) {
push(7);
push(2);
push(12);
push(1);
push(8);
System.out.println(st);
System.out.println("min is:::"+getMin());
pop();
pop();
System.out.println("min is:::"+getMin());
}
private static int getMin() {
// TODO Auto-generated method stub
return st.peek();
}
private static void pop() {
if(!st.isEmpty()){
st.pop();
}
}
private static void push(int i) {
if(st.isEmpty()){
st.push(i);
min=i;
}
else
{
if(i<min){
st.push(i);
min=i;
}
else
st.push(min);
}
}
/* private static void pop() {
if(!st.isEmpty() && !aux.isEmpty()){
st.pop();
aux.pop();
}
}*/
/* private static int getMin() {
if(!aux.isEmpty())
return aux.peek();
else
return -1;
}
*/
/* private static void push(int i) {
if(st.isEmpty() && aux.isEmpty())
{
st.push(i);
aux.push(i);
}
else
{
st.push(i);
int y=aux.peek();
if(i<y)
aux.push(i);
else
aux.push(y);
}
}*/
}