mirror of
https://github.com/halfrost/LeetCode-Go.git
synced 2025-07-30 23:52:03 +08:00
87 lines
1.6 KiB
Markdown
87 lines
1.6 KiB
Markdown
# [155. Min Stack](https://leetcode.com/problems/min-stack/)
|
|
|
|
## 题目
|
|
|
|
Design a stack that supports push, pop, top, and retrieving the minimum element in constant time.
|
|
|
|
push(x) -- Push element x onto stack.
|
|
pop() -- Removes the element on top of the stack.
|
|
top() -- Get the top element.
|
|
getMin() -- Retrieve the minimum element in the stack.
|
|
|
|
|
|
|
|
**Example**:
|
|
|
|
```
|
|
|
|
MinStack minStack = new MinStack();
|
|
minStack.push(-2);
|
|
minStack.push(0);
|
|
minStack.push(-3);
|
|
minStack.getMin(); --> Returns -3.
|
|
minStack.pop();
|
|
minStack.top(); --> Returns 0.
|
|
minStack.getMin(); --> Returns -2.
|
|
|
|
```
|
|
|
|
## 题目大意
|
|
|
|
这道题是一个数据结构实现题。要求实现一个栈的类,实现 push()、pop()、top()、getMin()。
|
|
|
|
|
|
## 解题思路
|
|
|
|
按照题目要求实现即可。
|
|
|
|
## 代码
|
|
|
|
```go
|
|
|
|
package leetcode
|
|
|
|
// MinStack define
|
|
type MinStack struct {
|
|
elements, min []int
|
|
l int
|
|
}
|
|
|
|
/** initialize your data structure here. */
|
|
|
|
// Constructor155 define
|
|
func Constructor155() MinStack {
|
|
return MinStack{make([]int, 0), make([]int, 0), 0}
|
|
}
|
|
|
|
// Push define
|
|
func (this *MinStack) Push(x int) {
|
|
this.elements = append(this.elements, x)
|
|
if this.l == 0 {
|
|
this.min = append(this.min, x)
|
|
} else {
|
|
min := this.GetMin()
|
|
if x < min {
|
|
this.min = append(this.min, x)
|
|
} else {
|
|
this.min = append(this.min, min)
|
|
}
|
|
}
|
|
this.l++
|
|
}
|
|
|
|
func (this *MinStack) Pop() {
|
|
this.l--
|
|
this.min = this.min[:this.l]
|
|
this.elements = this.elements[:this.l]
|
|
}
|
|
|
|
func (this *MinStack) Top() int {
|
|
return this.elements[this.l-1]
|
|
}
|
|
|
|
func (this *MinStack) GetMin() int {
|
|
return this.min[this.l-1]
|
|
}
|
|
|
|
``` |