mirror of
https://github.com/youngyangyang04/leetcode-master.git
synced 2025-07-08 16:54:50 +08:00
Merge pull request #884 from CJ-cooper6/master
添加225. 用队列实现栈 Go 两个队列实现版本
This commit is contained in:
@ -359,6 +359,72 @@ class MyStack:
|
|||||||
|
|
||||||
Go:
|
Go:
|
||||||
|
|
||||||
|
使用两个队列实现
|
||||||
|
```go
|
||||||
|
type MyStack struct {
|
||||||
|
//创建两个队列
|
||||||
|
queue1 []int
|
||||||
|
queue2 []int
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
func Constructor() MyStack {
|
||||||
|
return MyStack{ //初始化
|
||||||
|
queue1:make([]int,0),
|
||||||
|
queue2:make([]int,0),
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
func (this *MyStack) Push(x int) {
|
||||||
|
//先将数据存在queue2中
|
||||||
|
this.queue2 = append(this.queue2,x)
|
||||||
|
//将queue1中所有元素移到queue2中,再将两个队列进行交换
|
||||||
|
this.Move()
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
func (this *MyStack) Move(){
|
||||||
|
if len(this.queue1) == 0{
|
||||||
|
//交换,queue1置为queue2,queue2置为空
|
||||||
|
this.queue1,this.queue2 = this.queue2,this.queue1
|
||||||
|
}else{
|
||||||
|
//queue1元素从头开始一个一个追加到queue2中
|
||||||
|
this.queue2 = append(this.queue2,this.queue1[0])
|
||||||
|
this.queue1 = this.queue1[1:] //去除第一个元素
|
||||||
|
this.Move() //重复
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func (this *MyStack) Pop() int {
|
||||||
|
val := this.queue1[0]
|
||||||
|
this.queue1 = this.queue1[1:] //去除第一个元素
|
||||||
|
return val
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
func (this *MyStack) Top() int {
|
||||||
|
return this.queue1[0] //直接返回
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
func (this *MyStack) Empty() bool {
|
||||||
|
return len(this.queue1) == 0
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Your MyStack object will be instantiated and called as such:
|
||||||
|
* obj := Constructor();
|
||||||
|
* obj.Push(x);
|
||||||
|
* param_2 := obj.Pop();
|
||||||
|
* param_3 := obj.Top();
|
||||||
|
* param_4 := obj.Empty();
|
||||||
|
*/
|
||||||
|
```
|
||||||
|
|
||||||
|
使用一个队列实现
|
||||||
```go
|
```go
|
||||||
type MyStack struct {
|
type MyStack struct {
|
||||||
queue []int//创建一个队列
|
queue []int//创建一个队列
|
||||||
|
Reference in New Issue
Block a user