《剑指Offer》附加题_用两个队列实现一个栈_C++版

// 面试题9附加题:用两个队列实现栈
// 题目:用两个队列实现一个栈。栈的声明如下,请实现它的两个函数appendTail
// 和deleteHead,分别完成在栈尾部插入结点和在栈头部删除结点的功能。 #pragma once
#include<queue>
#include<exception> using namespace std; template <typename T> class CStack
{
public:
CStack();
~CStack(); void appendTail(const T& node);
T deleteHead(); private:
queue<T> queue1;
queue<T> queue2;
}; template<typename T> CStack<T>::CStack()
{
} template<typename T> CStack<T>::~CStack()
{
} // 插入元素
template<typename T> void CStack<T>::appendTail(const T& node)
{
if (queue1.size() > && queue2.size() > )
{
//异常情况
}
else
{
//插入到非空队列,如果均为空则插入到queue2中
if (queue1.size() == )
{
queue2.push(node);
}
else
{
queue1.push(node);
}
}
} template<typename T> T CStack<T>::deleteHead()
{
if (queue1.size() == && queue2.size() == )
{
//异常情况
throw new exception("stack is empty");
}
T head;
if (queue1.size() > )
{
while (queue1.size()>)
{
//queue1中的元素依次删除,并插入到queue2中,其中queue1删除最后一个元素
//相当于从栈中弹出队尾元素 T& data = queue1.front();
queue1.pop();
queue2.push(data);
}
head = queue1.front();
queue1.pop();
}
else
{
while (queue2.size()>)
{
//queue2中的元素依次删除,并插入到queue1中,其中queue2删除最后一个元素
//相当于从栈中弹出队尾元素 T& data = queue2.front();
queue2.pop();
queue1.push(data);
}
head = queue2.front();
queue2.pop();
}
return head;
}
#include"CStacks.h" // ====================测试代码====================
void test(char actual, char expected)
{
if (actual == expected)
printf("Test passed.\n");
else
printf("Test failed.\n");
} int main(int argc, char* argv[])
{
// 后进先出
CStack<char> stack; stack.appendTail('a');
stack.appendTail('b');
stack.appendTail('c'); char head = stack.deleteHead();
test(head, 'c'); head = stack.deleteHead();
test(head, 'b'); stack.appendTail('d');
head = stack.deleteHead();
test(head, 'd'); stack.appendTail('e');
head = stack.deleteHead();
test(head, 'e'); head = stack.deleteHead();
test(head, 'a'); //空栈删除,触发异常
//head = stack.deleteHead(); getchar();
return ;
}
《剑指Offer》附加题_用两个队列实现一个栈_C++版的更多相关文章
- 剑指offer编程题Java实现——面试题7相关题用两个队列实现一个栈
剑指offer面试题7相关题目:用两个队列实现一个栈 解题思路:根据栈的先入后出和队列的先入先出的特点1.在push的时候,把元素向非空的队列内添加2.在pop的时候,把不为空的队列中的size()- ...
- 剑指Offer编程题2——替换空格
剑指Offer编程题2——替换空格 题目描述 请实现一个函数,将一个字符串中的每个空格替换成“%20”.例如,当字符串为We Are Happy.则经过替换之后的字符串为We%20Are%20Happ ...
- 剑指Offer - 九度1509 - 树中两个结点的最低公共祖先
剑指Offer - 九度1509 - 树中两个结点的最低公共祖先2014-02-07 01:04 题目描述: 给定一棵树,同时给出树中的两个结点,求它们的最低公共祖先. 输入: 输入可能包含多个测试样 ...
- 剑指Offer - 九度1512 - 用两个栈实现队列
剑指Offer - 九度1512 - 用两个栈实现队列2013-11-29 21:23 题目描述: 用两个栈来实现一个队列,完成队列的Push和Pop操作.队列中的元素为int类型. 输入: 每个输入 ...
- 剑指 offer 第一题: 二维数组中的查找
打算写 图解剑指 offer 66 题 的系列文章,不知道大家有没有兴趣
- 剑指Offer编程题1——二维数组中的查找
剑指Offer编程题1---------------二维数组中的查找 题目描述 在一个二维数组中(每个一维数组的长度相同),每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序.请完 ...
- 剑指Offer - 九度1519 - 合并两个排序的链表
剑指Offer - 九度1519 - 合并两个排序的链表2013-11-30 22:04 题目描述: 输入两个单调递增的链表,输出两个链表合成后的链表,当然我们需要合成后的链表满足单调不减规则.(hi ...
- 《剑指Offer》题一~题十
一.赋值运算符函数 题目:如下为类型CMyString的声明,请为该类型添加赋值运算符函数. class CMyString { public: CMyString(char *pData = nul ...
- 【剑指Offer】5、用两个栈实现队列
题目描述: 用两个栈来实现一个队列,完成队列的Push和Pop操作. 队列中的元素为int类型. 解题思路: 本题的基本意图是:用两个后入先出的栈来实现先入先出的队列.对于这个问题,我 ...
随机推荐
- 201521123017 《Java程序设计》第11周学习总结
1. 本周学习总结 2. 书面作业 Q1.互斥访问与同步访问 完成题集4-4(互斥访问)与4-5(同步访问) 1.1 除了使用synchronized修饰方法实现互斥同步访问,还有什么办法实现互斥同步 ...
- JAVA课程设计-购物车 (201521123101 柏清晔)
1.团队课程设计博客链接 /[团队博客链接]http://www.cnblogs.com/yayaya/p/7062197.html 2.个人负责模板或任务说明 1.连接数据库 2.修改购物车的jsp ...
- Spark Streaming socketTextStream简单demo
正文 SparkStreaming的入口是StreamingContext,通过scala实现 一个简单的实时获取数据.代码SparkStreaming官网也可以找到. object SocketDS ...
- C#设计模式之二简单工厂模式(过渡模式)
一.引言 之所以写这个系列,是了为了自己更好的理解设计模式,也为新手提供一些帮助,我都是用最简单的.最生活化的实例来说明.在上一篇文章中讲解了单例模式,今天就给大家讲一个比较简单的模式--简单工厂模式 ...
- linux防火墙简单的使用
Centos升级到7之后,内置的防火墙已经从iptables变成了firewalld.所以,端口的开启还是要从两种情况来说明的,那就是iptables和firewalld.本文章参考官网教程基础 一. ...
- Jmeter之性能测试基础
1.概念:性能测试是通过自动化的测试工具模拟多种正常峰值及负载条件来对系统的各项性能指标进行测试.负载测试和压力测试都属于性能测试,两者可以结合进行.通过负载测试,确定在各种工作负载下系统的性能,目标 ...
- mapreduce自定义排序(map端1.4步)
3 3 3 2 3 1 2 2 2 1 1 1 -----------------期望输出 1 1 2 1 2 2 3 1 3 2 3 3 将以上数据进行排序,排序规则是:按照第一列升序排序,如果第一 ...
- 匹配替换第n个字符串
var name = "questions[0][question]",i=0; name.replace(/\[.+?\]/g, function(match, pos, ori ...
- 前端系列——jquery前端国际化解决方案“填坑日记”
前言:最近,新的平台还没有开发完成,原来的老项目又提出了新的需求:系统国际化.如果是前后端完全分离的开发模式,要做国际化,真的太简单了,有现成的解决方案,基于Node构建的时下热门的任何一种技术选型都 ...
- Linux入门(7) 脚本
1.宣告使用的shell为何 2.注明创建者 编写作用等 3.注释每一个功能函数 执行脚本 1.修改可执行权限 chmod 755 file.sh 2.sh file.sh 可以直接运行脚本 #!/b ...