队列的基本操作(数据结构)

队列的顺序实现

c 复制代码
#include <stdlib.h>
#include <iostream>
#include <stdio.h>

#define MaxSize 10//定义队列的长度

typedef struct{
	int front,rear;
	int data[MaxSize];
}SqQueue;

//初始化队列
void InitQueue(SqQueue &Q){
	Q.front=Q.rear=0;
} 

//判断队列是否为空
bool QueueEmpty(SqQueue Q){
	if(Q.front==Q.rear) return true;//空队列
	else return false; 
}

//入队
bool EnQueue(SqQueue &Q,int x){
	if((Q.rear+1)%MaxSize==Q.front){//判断队满
		return false; 
	}
	Q.data[Q.rear]=x;//新元素入队 
	Q.rear = (Q.rear+1)%MaxSize;//队尾指针加一取模 让队列循环使用 
	return true;
} 

//出队
int DeQueue(SqQueue &Q){
	if(Q.front==Q.rear) return false;//队列为空 
	int x;
	x = Q.data[Q.front];
	Q.front=(Q.front+1)%MaxSize;//对头指针后移 
	return x;
} 
 
//获取对头元素 
int GetHead(SqQueue &Q){
	if(Q.front==Q.rear) return false;
	int x;
	x = Q.data[Q.front];
	return x;
} 

//计算队列元素个数
int CountQueue(SqQueue &Q){
	if(Q.front==Q.rear) return false;
	int count;
	count = (Q.rear+MaxSize-Q.front)%MaxSize;
	return count;
}
 
//输出栈 
bool PrintSqQueue(SqQueue &Q){
	if(Q.front==Q.rear) return false;
	for(int i=Q.front;i<Q.rear;i++)
		printf("%d ",Q.data[i]);
	printf("\n");
	return true;
}

int main(){
	SqQueue Q;
	InitQueue(Q);
	printf("-----入队-----\n");
	EnQueue(Q,1);
	EnQueue(Q,2);
	EnQueue(Q,3);
	EnQueue(Q,4);
	EnQueue(Q,5);
	int count;
	count=CountQueue(Q);
	printf("队内元素个数为:%d\n",count);
	PrintSqQueue(Q);
	printf("-----出队-----\n");
	int x;
	x=DeQueue(Q);
	printf("%d出队\n",x);
	x=DeQueue(Q);
	printf("%d出队\n",x);
	x=DeQueue(Q);
	printf("%d出队\n",x);
	count=CountQueue(Q);
	printf("队内元素个数为:%d\n",count);
	PrintSqQueue(Q);
	return 0;
}

队列的链式实现

c 复制代码
#include <stdlib.h>
#include <iostream>
#include <stdio.h>

//链式队列结点 
typedef struct LinkNode{
	int data;
	struct LinkNode *next;
}LinkNode; 

//链式队列 
typedef struct{
	LinkNode *front,*rear;
}LinkQueue;

//队列初始化(带头结点) 
void InitQueue1(LinkQueue &Q){
	Q.front=Q.rear=(LinkNode*)malloc(sizeof(LinkNode));
	Q.front->next=NULL;
}

//队列初始化(不带头结点)
void InitQueue2(LinkQueue &Q){
	Q.front=NULL;
	Q.rear=NULL;
} 

//判断队列是否为空(带头结点)
bool IsEmpty1(LinkQueue Q){
	if(Q.front==Q.rear) return true;
	else return false; 
} 

//判断队列是否为空(不带头结点)
bool IsEmpty2(LinkQueue Q){
	if(Q.front==NULL) return true;
	else false;
} 

//入队(带头结点)
void EnQueue1(LinkQueue &Q,int x){
	LinkNode *s=(LinkNode *)malloc(sizeof(LinkNode));
	s->data=x;
	s->next=NULL;
	Q.rear->next=s;//新节点插入到rear之后 
	Q.rear=s;//修改表尾指针 
} 
 
//入队(不带头结点)
void EnQueue2(LinkQueue &Q,int x){
	LinkNode *s=(LinkNode *)malloc(sizeof(LinkNode));
	s->data=x;
	s->next=NULL;
	if(Q.front==NULL){//空队列中插入第一个元素 
		Q.front=s;//修改队头队尾指针 
		Q.rear=s;
	}
	else{//新节点插入到rear结点之后 
		Q.rear->next=s;
		Q.rear=s;
	}
}

//出队(带头结点) 
int DeQueue1(LinkQueue &Q){
	if(Q.front==Q.rear){//空 
		return false;
	}
	LinkNode *p=Q.front->next;
	int x;
	x=p->data;
	Q.front->next = p->next;
	if(Q.rear==p) Q.rear=Q.front;//最后一个结点出队,修改rear指针
	free(p);
	return x ;
} 

//出队(不带头结点)
int DeQueue2(LinkQueue &Q){
	if(Q.front==NULL) return false;//空 
	LinkNode *p=Q.front;
	int x;
	x=p->data; 
	Q.front=p->next;//修改front指针 
	if(Q.rear==p){//最后一个结点出队 
		Q.front=NULL;
		Q.rear=NULL;
	}
	free(p);
	return x; 
} 

//打印队列 (带头结点)
void PrintQueue1(LinkQueue &Q)
{
	LinkNode *temp=Q.front->next;
	printf("打印队列:");
	while(temp)
	{
		printf("%d ",temp->data);
		temp = temp->next;
	}
	printf("\n");
}

//打印队列 (不带头结点)
void PrintQueue2(LinkQueue &Q)
{
	LinkNode *temp=Q.front;
	printf("打印队列:");
	while(temp)
	{
		printf("%d ",temp->data);
		temp = temp->next;
	}
	printf("\n");
}

int main(){
	printf("--------带头结点-------\n");
	LinkQueue Q;
	InitQueue1(Q);
	printf("开始进队列\n");
	EnQueue1(Q,1);
	EnQueue1(Q,2);
	EnQueue1(Q,3);
	EnQueue1(Q,4);
	EnQueue1(Q,5);
	PrintQueue1(Q);//打印队列 
	if (!IsEmpty1(Q)) printf("非空队列\n");
	else printf("空队列\n");
	int x;
	x=DeQueue1(Q);
	printf("%d出队列\n",x);
	x=DeQueue1(Q);
	printf("%d出队列\n",x);
	x=DeQueue1(Q);
	printf("%d出队列\n",x);
	PrintQueue1(Q);//打印队列 
	
	printf("--------不带头结点-------\n");
	LinkQueue P;
	InitQueue2(P);
	printf("开始进队列\n");
	EnQueue2(P,1);
	EnQueue2(P,2);
	EnQueue2(P,3);
	EnQueue2(P,4);
	EnQueue2(P,5);
	PrintQueue2(P);//打印队列 
	if (!IsEmpty2(P)) printf("非空队列\n");
	else printf("空队列\n");
	int y;
	y=DeQueue2(P);
	printf("%d出队列\n",y);
	y=DeQueue2(P);
	printf("%d出队列\n",y);
	y=DeQueue2(P);
	printf("%d出队列\n",y);
	PrintQueue2(P);//打印队列 
	return 0;
}
相关推荐
Funny_AI_LAB18 分钟前
MetaAI最新开源Llama3.2亮点及使用指南
算法·计算机视觉·语言模型·llama·facebook
NuyoahC25 分钟前
算法笔记(十一)——优先级队列(堆)
c++·笔记·算法·优先级队列
jk_10128 分钟前
MATLAB中decomposition函数用法
开发语言·算法·matlab
penguin_bark1 小时前
69. x 的平方根
算法
一休哥助手1 小时前
Redis 五种数据类型及底层数据结构详解
数据结构·数据库·redis
这可就有点麻烦了1 小时前
强化学习笔记之【TD3算法】
linux·笔记·算法·机器学习
苏宸啊1 小时前
顺序表及其代码实现
数据结构·算法
lin zaixi()2 小时前
贪心思想之——最大子段和问题
数据结构·算法
FindYou.2 小时前
C - Separated Lunch
算法·深度优先
夜雨翦春韭2 小时前
【代码随想录Day30】贪心算法Part04
java·数据结构·算法·leetcode·贪心算法