数据结构-链队列



一、队列的定义

队列是一种先进先出的线性表,它只允许在表的一端进行插入,而在另一端删除元素。这和我们日常生活中的排队是一致的,最早进入队列的元素最早离开。队列的结构图如下所示:
在这里插入图片描述

二、链队列结构

链队列,是队列的一种,只不过运用链表的知识对队列进行再设计。结构图:
在这里插入图片描述

三、基本操作

1、结构体

第一个结构体是链队列的节点,第二个结构体是存放链队列的首尾指针。

typedef struct linkNode
{
	int data;
	struct linkNode* next;
}*linkNodeptr;

typedef struct linkQueue
{
	linkNodeptr front;
	linkNodeptr rear;
}*linkQueueptr;

2.初始化

linkQueueptr initQueue()
{
	linkQueueptr resultptr=(linkQueueptr)malloc(sizeof(struct linkQueue));
	linkNodeptr headerptr=(linkNodeptr)malloc(sizeof(struct linkNode));
	
	headerptr->data=-1;
	headerptr->next=NULL;
	
	resultptr->front=headerptr;
	resultptr->rear=headerptr;
	return resultptr;
}

3.进队

void enqueue(linkQueueptr pQueueptr,int pelement)
{
	linkNodeptr tempNodeptr=(linkNodeptr)malloc(sizeof(struct linkNode));
	tempNodeptr->data=pelement;
	tempNodeptr->next=NULL;
	
	pQueueptr->rear->next=tempNodeptr;
	pQueueptr->rear=tempNodeptr;
}

4.出队

int dequeue(linkQueueptr pQueueptr)
{
	int resultValue;
	linkNodeptr tempNodeptr;
	
	if(pQueueptr->front==pQueueptr->rear)
	{
		printf("队列为空! 无法删除!\r\n");
		return -1;
	}
	tempNodeptr=pQueueptr->front->next;
	resultValue=tempNodeptr->data;
	pQueueptr->front->next=pQueueptr->front->next->next;
	
	if(pQueueptr->rear==tempNodeptr)
	{
		pQueueptr->rear=pQueueptr->front;
	}
	
	free(tempNodeptr);
	return resultValue;
}

5.遍历

void printQueue(linkQueueptr pQueueptr)
{
	linkNodeptr tempptr=pQueueptr->front->next;
	while(tempptr)
	{
		printf("%d ",tempptr->data);
		tempptr=tempptr->next; 
	}
	printf("\r\n");
}

四、完整代码

#include<stdio.h>
#include<malloc.h>

typedef struct linkNode
{
	int data;
	struct linkNode* next;
}*linkNodeptr;

typedef struct linkQueue
{
	linkNodeptr front;
	linkNodeptr rear;
}*linkQueueptr;

linkQueueptr initQueue()
{
	linkQueueptr resultptr=(linkQueueptr)malloc(sizeof(struct linkQueue));
	linkNodeptr headerptr=(linkNodeptr)malloc(sizeof(struct linkNode));
	
	headerptr->data=-1;
	headerptr->next=NULL;
	
	resultptr->front=headerptr;
	resultptr->rear=headerptr;
	return resultptr;
}

void printQueue(linkQueueptr pQueueptr)
{
	linkNodeptr tempptr=pQueueptr->front->next;
	while(tempptr)
	{
		printf("%d ",tempptr->data);
		tempptr=tempptr->next; 
	}
	printf("\r\n");
}

void enqueue(linkQueueptr pQueueptr,int pelement)
{
	linkNodeptr tempNodeptr=(linkNodeptr)malloc(sizeof(struct linkNode));
	tempNodeptr->data=pelement;
	tempNodeptr->next=NULL;
	
	pQueueptr->rear->next=tempNodeptr;
	pQueueptr->rear=tempNodeptr;
}

int dequeue(linkQueueptr pQueueptr)
{
	int resultValue;
	linkNodeptr tempNodeptr;
	
	if(pQueueptr->front==pQueueptr->rear)
	{
		printf("队列为空! 无法删除!\r\n");
		return -1;
	}
	tempNodeptr=pQueueptr->front->next;
	resultValue=tempNodeptr->data;
	pQueueptr->front->next=pQueueptr->front->next->next;
	
	if(pQueueptr->rear==tempNodeptr)
	{
		pQueueptr->rear=pQueueptr->front;
	}
	
	free(tempNodeptr);
	return resultValue;
}

void test()
{
	linkQueueptr tempQueueptr;
	tempQueueptr=initQueue();
	enqueue(tempQueueptr,10);
	enqueue(tempQueueptr,100);
	enqueue(tempQueueptr,1000);
	enqueue(tempQueueptr,10000);
	printQueue(tempQueueptr);
	
	printf("dequeue gets %d!\r\n",dequeue(tempQueueptr));
	printf("dequeue gets %d!\r\n",dequeue(tempQueueptr));
	printf("dequeue gets %d!\r\n",dequeue(tempQueueptr));
	printf("dequeue gets %d!\r\n",dequeue(tempQueueptr));
	printf("dequeue gets %d!\r\n",dequeue(tempQueueptr));
	
}
int main()
{
	test();
	return 0;
}

运行结果:

10 100 1000 10000
dequeue gets 10!
dequeue gets 100!
dequeue gets 1000!
dequeue gets 10000!
队列为空! 无法删除!
dequeue gets -1!
  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值