兩個棧實現一個隊列:
template<class T>
class CQueue
{
public:
void Push(const T& element)
{
stack1.push(element);
}
void Pop()
{
if (stack2.empty())
{
while (!stack1.empty())
{
stack2.push(stack1.top());
stack1.pop();
}
}
if (stack2.empty())
{
cout<<"queue is empty"<<endl;
assert(false);
}
stack2.pop();
}
bool Empty()
{
if (stack1.empty() && stack2.empty())
return true;
else
return false;
}
T Front()
{
if (!stack2.empty())
{
return stack2.top();
}
else
{
while (!stack1.empty())
{
stack2.push(stack1.top());
stack1.pop();
}
if (stack2.empty())
{
cout<<"queue is empty"<<endl;
assert(false);
}
return stack2.top();
}
}
private:
stack<T> stack1;
stack<T> stack2;
};兩個隊列實現一個棧:
template<class T>
class CStack
{
public:
void Push(const T& element)
{
queue1.push(element);
}
void Pop()
{
if (queue1.empty())
{
cout<<"stack is empty"<<endl;
assert(false);
}
while (queue1.size() != 1)
{
queue2.push(queue1.front());
queue1.pop();
}
queue1.pop();
while (!queue2.empty())
{
queue1.push(queue2.front());
queue2.pop();
}
}
bool Empty()
{
if (queue1.empty())
return true;
else
return false;
}
T Top()
{
if (queue1.empty())
{
cout<<"stack is empty"<<endl;
assert(false);
}
return queue1.back();
}
private:
queue<T> queue1;
queue<T> queue2;
};免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。