C++链队列类实现

#include <iostream>

using namespace std;

typedef int DataType;

#define MAXSIZE 100

struct DataNode{
	DataType data;
	DataNode *pNextNode;
	DataNode(DataType data2);
};

DataNode::DataNode(DataType data2)
{
	data=data2;
}

class MyQueue
{
public:
	MyQueue();
	~MyQueue();
	bool clearQueue();
	bool IsQueueEmpty();
	int GetQueueLength();
	bool GetQueueHead(DataType &data);
	bool DeleteQueueHead(DataType &data);
	bool InsertQueueEnd(DataType data);

private:
	DataNode *QueueHead;
	DataNode *QueueEnd;
	int QueueLength;
};

int MyQueue::GetQueueLength()
{
	return QueueLength;
}

bool MyQueue::clearQueue()
{
	while(QueueHead!=QueueEnd)
	{
		DataNode *p=NULL;
		p=QueueHead->pNextNode;
		QueueHead->pNextNode=p->pNextNode;
		if(p==QueueEnd)QueueHead=QueueEnd;
		delete p;
	}
	QueueLength=0;
	return true;
}

bool MyQueue::IsQueueEmpty()
{
	if(QueueHead==QueueEnd)
		return true;
	else
	{
		return false;
	}
}

bool MyQueue::DeleteQueueHead(DataType &data)
{
	if(QueueHead==QueueEnd)
		return false;
	DataNode *p=NULL;
	p=QueueHead->pNextNode;
	data=p->data;
	QueueHead->pNextNode=p->pNextNode;
	if(p==QueueEnd)QueueEnd=QueueHead;
	delete p;
	--QueueLength;
	return true;
}

bool MyQueue::GetQueueHead(DataType &data)
{
	if(QueueHead==QueueEnd)
		return false;
	data=QueueHead->pNextNode->data;
	--QueueLength;
	return true;
}

bool MyQueue::InsertQueueEnd(DataType data)
{
	DataNode *node=new DataNode(data);//应该判断new出错怎么办,但是一般new不会出错
	node->pNextNode=NULL;
	QueueEnd->pNextNode=node;
	QueueEnd=node;
	++QueueLength;
	return true;
}

MyQueue::MyQueue()
{
	QueueHead=new DataNode(0);
	QueueHead->pNextNode=NULL;
	QueueEnd=QueueHead;
	QueueLength=0;
}

MyQueue::~MyQueue()
{
}

void main()
{
	MyQueue test;
	for(int i=0;i<10;++i)
	{
		test.InsertQueueEnd(i);
	}
	cout<<test.IsQueueEmpty()<<"空不空"<<test.GetQueueLength()<<endl;
	/*test.clearQueue();
	cout<<test.IsQueueEmpty()<<"空不空"<<test.GetQueueLength()<<endl;*/

	DataType num;

	for(int i=0;i<10;++i)
	{
		test.DeleteQueueHead(num);
		cout<<num<<endl;
	}

	cout<<test.IsQueueEmpty()<<"    "<<test.GetQueueLength()<<endl;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值