题解 | #由两个栈组成的队列#

由两个栈组成的队列

http://www.nowcoder.com/practice/6bc058b32ee54a5fa18c62f29bae9863

package main
import (
	"bufio"
	"fmt"
	"os"
	"strconv"
	"strings"
)

func main() {
	numofAction := 0
	l := &stacklist{[]int{}, []int{}}
	fmt.Scanln(&numofAction)
	sc := bufio.NewScanner(os.Stdin)
	action, num := "", 0
	for i := 0; i < numofAction; i++ {
		sc.Scan()
		orderString := strings.Split(sc.Text()," ")
		action = orderString[0]
		switch action {
		case "add":
			num,_ = strconv.Atoi(orderString[1])
			l.add(num)
		case "poll":
			l.pop()
		case "peek":
            fmt.Println(l.peek())
		}

	}
}

type stacklist struct {
	stack1 []int
	stack2 []int
}

func (s *stacklist) add(i int) {
	s.stack1 = append(s.stack1, i)
}
func (s *stacklist) pop() {
	if len(s.stack2) == 0 {
		s.stack2 = append(s.stack2, s.stack1...)
		s.stack1 = []int{}
		s.stack2 = s.stack2[1:]
	} else {
		s.stack2 = s.stack2[1:]
	}
}
func (s *stacklist) peek() int {
	if len(s.stack2) == 0 {
		s.stack2 = append(s.stack2, s.stack1...)
		s.stack1 = []int{}
		i := s.stack2[0]
		return i
	} else {
		i := s.stack2[0]
		return i
	}
}

全部评论

相关推荐

评论
点赞
收藏
分享
正在热议
# 25届秋招总结 #
443331次浏览 4520人参与
# 春招别灰心,我们一人来一句鼓励 #
42187次浏览 537人参与
# 阿里云管培生offer #
120420次浏览 2220人参与
# 地方国企笔面经互助 #
7973次浏览 18人参与
# 同bg的你秋招战况如何? #
77166次浏览 569人参与
# 实习必须要去大厂吗? #
55811次浏览 961人参与
# 北方华创开奖 #
107469次浏览 600人参与
# 虾皮求职进展汇总 #
116310次浏览 887人参与
# 如果你有一天可以担任公司的CEO,你会做哪三件事? #
11683次浏览 289人参与
# 实习,投递多份简历没人回复怎么办 #
2454962次浏览 34861人参与
# 提前批简历挂麻了怎么办 #
149927次浏览 1978人参与
# 在找工作求抱抱 #
906096次浏览 9421人参与
# 如果公司给你放一天假,你会怎么度过? #
4762次浏览 55人参与
# 你投递的公司有几家约面了? #
33209次浏览 188人参与
# 投递实习岗位前的准备 #
1196037次浏览 18550人参与
# 机械人春招想让哪家公司来捞你? #
157648次浏览 2267人参与
# 双非本科求职如何逆袭 #
662384次浏览 7397人参与
# 发工资后,你做的第一件事是什么 #
12806次浏览 62人参与
# 工作中,努力重要还是选择重要? #
35906次浏览 384人参与
# 简历中的项目经历要怎么写? #
86937次浏览 1516人参与
# 参加完秋招的机械人,还参加春招吗? #
20153次浏览 240人参与
# 我的上岸简历长这样 #
452074次浏览 8089人参与
牛客网
牛客企业服务