数据结构--队列实现舞伴配对问题+(舞伴程序++c++).doc

数据结构--队列实现舞伴配对问题+(舞伴程序++c++).doc

ID:59523974

大小:23.50 KB

页数:7页

时间:2020-11-07

数据结构--队列实现舞伴配对问题+(舞伴程序++c++).doc_第1页
数据结构--队列实现舞伴配对问题+(舞伴程序++c++).doc_第2页
数据结构--队列实现舞伴配对问题+(舞伴程序++c++).doc_第3页
数据结构--队列实现舞伴配对问题+(舞伴程序++c++).doc_第4页
数据结构--队列实现舞伴配对问题+(舞伴程序++c++).doc_第5页
资源描述:

《数据结构--队列实现舞伴配对问题+(舞伴程序++c++).doc》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库

1、#include#includeconstboolTURE=1;constboolFAULT=0;usingstd::cout;usingstd::cin;usingstd::endl;classNode{//链式堆栈的节点类public:Node();//构造函数重载1Node(int,int,int,Node*);//构造函数重载2voidconstget_data(int&,int&,int&);//取节点数据voidput_data(int,int,int);//置节点

2、数据boolput_next(Node*);//置节点的前驱节点域boolput_prior(Node*);//置结点的后继结点域Node*constget_next()const;//取结点的前驱结点域Node*constget_prior()const;//取结点的后继结点域private:Node*next;Node*prior;intminute;intsecond;intnum;};Node::Node(){minute=NULL;second=NULL;num=0;next=NULL;prior=NULL;

3、}Node::Node(intx,inty,intz,Node*p){minute=x;second=y;num=z;next=NULL;prior=p;}voidconstNode::get_data(int&x,int&y,int&z){x=minute;y=second;z=num;}voidNode::put_data(intx,inty,intz){minute=x;second=y;num=z;}boolNode::put_next(Node*n){next=n;returnTURE;}boolNode::

4、put_prior(Node*p){prior=p;returnTURE;}Node*constNode::get_next()const{returnnext;}Node*constNode::get_prior()const{returnprior;}classQueue{public:Queue();//堆栈类的构造函数intget_length(void);//取堆栈的长度boolpush(int,int,int);//数据压栈boolpop(int&,int&,int&);//数据出栈voidprint(vo

5、id);intconstseach(int);//搜索堆栈数据protected:Nodebase;//根节点Node*top;//顶节点intlength;};Queue::Queue():base()//构造函数,数据初始化{length=0;top=&base;}intQueue::get_length(void)//取长度{if(length<0)length=0;returnlength;}boolQueue::push(intminute,intsecond,intnum)//数据压栈{if(top!=NU

6、LL){length++;Node*temp=newNode(minute,second,num,top);top->put_next(temp);top=temp;}else{returnFAULT;}returnTURE;}boolQueue::pop(int&minute,int&second,int&num){if(base.get_next()!=NULL){length--;Node*temp=base.get_next();temp->get_data(minute,second,num);if(temp

7、->get_next()!=NULL){Node*temp1=temp->get_next();temp1->put_prior(&base);base.put_next(temp1);}else{top=&base;base.put_next(NULL);}deletetemp;}else{returnFAULT;}returnTURE;}intconstQueue::seach(intnum)//搜索堆栈数据{Node*temp;intx,y,z;temp=&base;while(temp!=NULL){temp-

8、>get_data(x,y,z);if(x==num)return1;temp=temp->get_next();}return0;}voidQueue::print()//打印堆栈{Node*temp;intx,y,z,n=1;temp=base.get_next();if(temp==NULL)cout<<"数据为空"<

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。