《剑指offer》用两个栈实现队列
2016-06-28 14:27
441 查看
一、题目描述
用两个栈来实现一个队列,完成队列的Push和Pop操作。 队列中的元素为int类型。二、输入描述
三、输出描述
四、牛客网提供的框架
class Solution { public: void push(int node) { } int pop() { } private: stack<int> stack1; stack<int> stack2; };
五、解题思路
使用两个堆栈,其中一个是用来存储数据,另外一个是辅助“出队列”作用。入队是,保存到堆栈stack1中。这时堆栈里数据的顺序刚好跟队列的相反。出队列时,通过辅助栈stack2的作用,取出栈底元素。出队列后,再把辅助栈的数据放回stack1中。六、代码
class Solution { public: void push(int node) { stack1.push(node); } int pop() { int len = stack1.size(); if(len < 1) return -1; for(int i = 0; i < len - 1; i++) { int top = stack1.top(); stack2.push(top); stack1.pop(); } int headNum = stack1.top(); stack1.pop(); for(int i = 0; i < len - 1; i++) { int top = stack2.top(); stack1.push(top); stack2.pop(); } return headNum; } private: stack<int> stack1; stack<int> stack2; };
相关文章推荐
- JavaScript强化教程-JS面向对象编程 ...
- es6继承 vs js原生继承(es5)
- js 输入验证
- JavaScript强化教程-cookie对象
- React Native开发之动画(Animations)
- Node.js 获取客户端IP
- JavaScript强化教程——DOM编程(两种控制div移动的方法)
- CSS3中:only-child选择器的实例场景
- jQuery操作下拉框
- ReactJS学习系列课程(React 性能优化及immutable使用)
- JSPatch热修复的使用的那些深坑
- 写一个更好的Javascript DOM库
- js滚动到顶部底部代码
- HTML属性
- BufferedInputStream和FileInputStream的区别
- 写给 Node.js 学徒的 7 个建议
- HTML 事件属性
- jQuery的.bind()、.live()和.delegate()之间区别
- jQuery的.bind()、.live()和.delegate()之间区别
- 'release' is unavailable: not available in automatic reference counting modeAutomatic .