当前位置: 编程技术>c/c++/嵌入式
C++中用两个标准容器stack,实现一个队列的方法详解
来源: 互联网 发布时间:2014-10-17
本文导语: 代码如下所示: 代码如下:// StackToQueue.cpp : 定义控制台应用程序的入口点。//用两个标准容器stack,实现一个队列#include "stdafx.h"#include #include using namespace std;template class StackToQueue{public: StackToQueue() { stack1; stack2; } void push(T...
代码如下所示:
// StackToQueue.cpp : 定义控制台应用程序的入口点。
//用两个标准容器stack,实现一个队列
#include "stdafx.h"
#include
#include
using namespace std;
template
class StackToQueue
{
public:
StackToQueue()
{
stack1;
stack2;
}
void push(T e)
{
while (!stack2.empty())
{
T temp;
temp = stack2.top();
stack2.pop();
stack1.push(temp);
}
stack2.push(e);
while (!stack1.empty())
{
T temp;
temp = stack1.top();
stack1.pop();
stack2.push(temp);
}
}
void pop()
{
stack2.pop();
}
T front()
{
if (!empty())
{
return stack2.top();
}
else
{
return NULL;
}
}
bool empty()
{
return stack2.empty();
}
size_t size()
{
return stack2.size();
}
private:
stack stack1, stack2;
};
int _tmain(int argc, _TCHAR* argv[])
{
StackToQueue queue;
int i(0);
cout i)
{
queue.push(i);
}
cout
代码如下:
// StackToQueue.cpp : 定义控制台应用程序的入口点。
//用两个标准容器stack,实现一个队列
#include "stdafx.h"
#include
#include
using namespace std;
template
class StackToQueue
{
public:
StackToQueue()
{
stack1;
stack2;
}
void push(T e)
{
while (!stack2.empty())
{
T temp;
temp = stack2.top();
stack2.pop();
stack1.push(temp);
}
stack2.push(e);
while (!stack1.empty())
{
T temp;
temp = stack1.top();
stack1.pop();
stack2.push(temp);
}
}
void pop()
{
stack2.pop();
}
T front()
{
if (!empty())
{
return stack2.top();
}
else
{
return NULL;
}
}
bool empty()
{
return stack2.empty();
}
size_t size()
{
return stack2.size();
}
private:
stack stack1, stack2;
};
int _tmain(int argc, _TCHAR* argv[])
{
StackToQueue queue;
int i(0);
cout i)
{
queue.push(i);
}
cout