1. 基础
10年积累的网站制作、成都网站设计经验,可以快速应对客户对网站的新想法和需求。提供各种问题对应的解决方案。让选择我们的客户得到更好、更有力的网络服务。我虽然不认识你,你也不认识我。但先网站设计后付款的网站建设流程,更有鹿泉免费网站建设让你可以放心的选择与我们合作。队列:先进先出,即插入数据在队尾进行,删除数据在队头进行;
栈:后进先出,即插入与删除数据均在栈顶进行。
2. 思路
两个栈实现一个队列的思想:用pushStack栈作为push数据的栈,用popStack栈作为pop数据的栈。
3. 代码
#include <iostream> #include <stack> #include <exception> template<class T> class MyQueue { public: void push(const T& num); // 入队列 T pop(); // 出队列 T top(); private: std::stack<T> pushStack; std::stack<T> popStack; }; template<typename T> void MyQueue<T>::push(const T& num) { pushStack.push(num); } template<typename T> T MyQueue<T>::pop() { if (pushStack.empty() && popStack.empty()) { // 如果二个栈都为空 throw std::runtime_error("queue is empty"); } else if (popStack.empty()) { // 如果popStack为空,将pushStack全部元素倒popStack while (!pushStack.empty()) { T data = pushStack.top(); // 获取pushStack栈顶元素 pushStack.pop(); // 出栈 popStack.push(data); } } T data = popStack.top(); popStack.pop(); return data; } template<typename T> T MyQueue<T>::top() { if (pushStack.empty() && popStack.empty()) { // 如果二个栈都为空 throw std::runtime_error("queue is empty"); } else if (popStack.empty()) { // 如果popStack为空,将pushStack全部元素倒popStack while (!pushStack.empty()) { T data = pushStack.top(); // 获取pushStack栈顶元素 pushStack.pop(); // 出栈 popStack.push(data); } } else { // 如果popStack不为空的话直接返回popStack栈顶 T data = popStack.top(); return data; } } int main() { MyQueue<int> myQueue1; myQueue1.push(1); myQueue1.push(2); myQueue1.push(3); myQueue1.push(4); std::cout << "current pop is:" << myQueue1.pop() << std::endl; std::cout << "current pop is:" << myQueue1.pop() << std::endl; std::cout << "current pop is:" << myQueue1.pop() << std::endl; std::cout << "current pop is:" << myQueue1.pop() << std::endl; std::cout << "current pop is:" << myQueue1.pop() << std::endl; return 0; }
另外有需要云服务器可以了解下创新互联建站www.cdcxhl.com,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。
分享题目:C++利用两个栈实现队列的方法-创新互联
文章源于:https://www.cdcxhl.com/article12/dgssdc.html
成都网站建设公司_创新互联,为您提供移动网站建设、网站建设、服务器托管、网站营销、微信小程序、品牌网站设计
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联