剑指offer--两个栈实现一个队列
来源:互联网 发布:小程序连接数据库 编辑:程序博客网 时间:2024/05/13 00:47
题目:两个栈实现一个队列
分析:
方法一:
s1是入栈的,s2是出栈的。- 入队列,直接压到s1是就行了
- 出队列,先把s1中的元素全部出栈压入到s2中,弹出s2中的栈顶元素;再把s2的所有元素全部压回s1中
缺点:有大量元素要push和pop,效率不高
方法二:
s1表示入队的,s2表示出队列的,保证所有元素在一个栈中
入队列:如果s1为空,把s2中所有的元素倒出压到s1中;否则直接压入s1
出队列:如果s2不为空,把s2中的栈顶元素直接弹出;否则,把s1的所有元素全部弹出压入s2中,再弹出s2的栈顶元素
较方法一来说,减少了一写冗余
方法三:
s1是入栈的,s2是出栈的。
- 入队列:直接压入s1即可
- 出队列:如果s2不为空,把s2中的栈顶元素直接弹出;否则,把s1的所有元素全部弹出压入s2中,再弹出s2的栈顶元素
比较
与实现二相比较,入队直接入即可,感觉此时已是最优。
void InQueue(stack* s1,stack* s2,int k){push(s1,k);}void OutQueue(stack* s1,stack* s2){if(IsEmpty(s2) == 1){while(IsEmpty(s1)== 0){push(s2,pop(s1));}}if(IsEmpty(s2) == 1){cout<<"Empty"<<endl;}return pop(s2);}
1 4
- 【剑指offer】两个栈实现一个队列
- 【剑指offer】两个队列实现一个栈
- 两个队列实现一个栈-剑指offer
- 剑指offer-两个栈实现一个队列
- 剑指offer--两个栈实现一个队列
- 【剑指offer】两个栈实现一个队列
- 【剑指offer】两个队列实现一个栈
- 剑指offer--两个栈实现一个队列
- 剑指offer-两个栈实现一个队列
- 【剑指Offer】两个栈实现一个队列
- 剑指Offer--两个栈实现一个队列
- 【剑指offer】用两个栈实现一个队列,用两个队列实现一个栈
- 《剑指Offer》面试题:用两个队列实现一个栈
- 【剑指offer】两个栈实现一个队列 push pop
- 【面试题】剑指Offer-7-两个栈实现一个队列
- 剑指offer系列----用两个栈实现一个队列
- 剑指offer-用两个栈实现一个队列
- 剑指offer 7---使用两个队列实现一个栈
- 方差的分母是n还是n-1?????????
- struct1与struct2的区别
- myelipse初学者遇到的小问题
- 关于网狐棋牌6603源码的整理、编译和搭建
- python opencv入门 鼠标绘图(4)
- 剑指offer--两个栈实现一个队列
- Wolf从零学编程-用Django撸个Blog(三)
- 2017.03 JAVA 面试题 中高级
- Linux C 冒泡排序
- CentOS6.5系统"libc.so.6: version 'GLIBC_2.15' not found"解决方法
- Android--Android中使用广播BroadcastReceiver进行用户强制下线功能
- Cookie简单用法
- AhShare-冀银社交化分享组件
- Git生成 SSH 公钥