代码随想录冲冲冲 Day10 栈与队列part01

232. 用栈实现队列

在用stack实现queue时,需要两个stack一个作为输入 一个作为输出

push()就是普通的push

pop()首先在out stack为空时 首先要把in stack所有的东西通过.top()

全部放入out stack中,每加入一个要把元素从in stack中pop掉

这种情况里其实在in -> out的过程中,是把in的元素倒序加入out

这是的result就是out.top()也就是in中原本最先入stack的

这样也符合queue的pop的操作

peek的话 对比pop只不过是是不删除 所以直接调用pop()然后把pop的值重新加回来就行了

empty就是要检验是不是in和out的stack都是空的

225. 用队列实现栈

跟上一样 也是需要两个queue 

push也是一样

pop 首先要对于que1.size()-1进行while loop原因是要留下queue1中

最晚进入的,que2会一直push que1的front,同时que1会进行pop(

剩下的就是result (就是que1最后的那个)

在得到答案后que1要把这个pop出去,这时要把que2重新赋给que1

这是的que1就变成了跟刚刚一样只是把result去掉的状态

最后要对于que2进行清空,que2的作用其实也就是一直给que1做备份

top是一样的,逻辑不变的情况下,只要把result也放入que2中再赋值就可以了

empty只要看que1是否空就可以了,因为que2会一直被清空

20. 有效的括号

这道题就是匹配括号,首先当s中时奇数个数时,一定不可能匹配,所以return false

创建一个stack,s是{ [ (分别在stack中添加}])

当遇到s[i]为有括号时就会看stack的最后一个进入的是否一样

当出现不一样或者stack是空的情况 return false

当遇到一样的情况是 就把stack中的右括号 pop掉

最后只要return stack.empty就可以了 如果全部匹配上stack应该会被清空

删除字符串中的所有相邻重复项

新建一个stack,如果stack中顶不是s那么就放入,如果是就消掉,也就是pop掉

然后string result只要一个一个把stack的top加进去就行了

加完之后因为stack的原因是反着一个一个放进来的 所以要整体reverse一下

  • 4
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值