免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 1136 | 回复: 0
打印 上一主题 下一主题

[Linux资讯] linux 2个statck 实现一个 队列 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2013-01-11 19:46 |只看该作者 |倒序浏览
linux 两个Stack实现一个 队列
/*   
*题名:linux 两个Stack实现一个 队列
*作者:
*日期:2012-09-08
*来源 :www.01safe.com
*/
#include <iostream>
#include <stack>

using namespace std;

class MyQueue{
public:
          void enqueue(int data);
          int  dequeue();
          bool isEmpty();
private:
        stack<int> s1,s2;
};

void MyQueue::enqueue(int data)
{
        s1.push(data);
}

int MyQueue::dequeue()
{
        if(s2.empty()){
                while(!s1.empty())
                {
                        s2.push(s1.top());
                        s1.pop();
                }
        }
        int i = -1;
        if(!s2.empty()){
                i = s2.top();
                s2.pop();
        }
        return i;
}

bool MyQueue::isEmpty()
{
        return (s1.empty() && s2.empty());
}

int main()
{
        MyQueue my;
        for(int i = 0; i < 10; i++)
        {
                my.enqueue(i+1);
        }
        do{
                cout<<my.dequeue()<<" ";
        }while(!my.isEmpty());
        cout<<endl;
        return 0;
}
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP