队列实验(链式结构)

队列实验(链式结构)

用链式存储结构实现队列

头文件

#pragma once
struct Node {
	int data;
	Node* next;
};
class LinkQueue
{
public:
	LinkQueue();
	~LinkQueue();
	void enQueue(int x);//入队
	void deQueue();//出队
	int getHead();//获取队头元素
	bool empty();//判空
private:
	Node* front, *rear;//队头队尾指针
};

源文件

#include "LinkQueue.h"
LinkQueue::LinkQueue() {
	Node *s = new Node;//头结点
	s->next = nullptr;
	front = rear = s;//队头队尾指针均指向头结点
}
LinkQueue::~LinkQueue() {
	Node* p = nullptr;//工作指针
	while (p != nullptr) {
		p = front->next;
		delete front;
	}
}
void LinkQueue::enQueue(int x) {
	Node* s = new Node;//申请新结点
	s->data = x;
	s->next = nullptr;
	rear->next = s;//结点入队
	rear = s;
}
void LinkQueue::deQueue() {
	Node* p = nullptr;
	if (rear == front)throw"下溢";
	p = front->next;//暂存队头元素
	front->next = p->next;//队头元素摘链
	if (p->next == nullptr)rear = front;//出队前队列长度为1
	delete p;
}
int LinkQueue::getHead() {
	return front->next->data;
	
}
bool LinkQueue::empty() {
	if (front == rear)return true;
	return false;
	
}

测试文件

#include<iostream>
using namespace std;
#include"LinkQueue.h"

int main() {
    LinkQueue que;
    cout <<"判断队列是否为空:"<< que.empty()<<endl;
    //入队4个元素
    que.enQueue(1);
    que.enQueue(3);
    que.enQueue(1);
    que.enQueue(4);
    cout << "取队首元素:" << que.getHead()<< endl;
    //出队1个元素
    que.deQueue();
    cout << "再取一次队首元素:" << que.getHead() << endl;
    cout << "再次判断栈是否为空:" << que.empty() << endl;
}

测试结果

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值