C语言实现顺序循环队列实例

 更新时间:2022年02月10日 14:35:16   作者:犀牛超人  
大家好,本篇文章主要讲的是C语言实现顺序循环队列实例,感兴趣的同学赶快来看一看吧,对你有帮助的话记得收藏一下

一、队列和循环队列基本概念

队列:

和栈相反,队列是一种先进先出(FIFO)的线性表。只允许在一端插入,在另一端删除。

允许插入的叫"队尾"(rear),允许删除的叫"队头"(front)。

入队操作:L->rear++;   L->data[L->rear]=x;(需要入队的元素)

出队操作:L->front++;  x=L->data[L->front];

求队长:队长=(L->rear)-(L->front);

队空:L->rear==L->front==-1;

队满:队长=max

使用场景:一切具备先来后到的任务场景

循环队列:

  和队列类似,只不过队头和队尾相连,解决了队列的假溢出现象(队尾指针达到申请空间的最大时,系统会认定空间满,但是队头指针如果不为-1则就是假溢出)。
入队:L->rear==(L->rear+1)%max;
出队:L->front==(L->front+1)%max;
队满:由图可知 队满和队空条件重复,所以为了避免这一情况现如今有两种方法:1.少用一个元素空间,也就是说front指针在定义时指向0的位置,这样才能使front和rear之间空出一个元素空间。2.这个方法比较容易理解,就是定义一个Num值来记录元素个数,num==0时则队空,num==max时则队满。
具体操作:(L->rear+1)%max==front;  num==max;

队空:L->rear==L->front;
队长:分两种情况:1.头指针在尾指针之后:按普通队列求法。2.头指针在尾指针之前:队长=L->rear+(max-(L->front));

二、代码实操

 图示:

 具体代码:

#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#define ture 1
#define false 0
#define max 5
typedef struct {
	int data[max];
	int front,rear;
}cteam,*team;
static int num=0;  //全局变量 num  
//初始队列
int Initteam(team &L){
	L=(cteam *)malloc(sizeof(cteam));
	if(L==NULL){
		printf("申请空间失败!");
		return false;
	}
	L->front=L->rear=-1;
	return true;
}
//入队
int pushteam(team &L,int x){
	if(num==max){
		printf("队满");
		return false;
	}else{
		L->rear=(L->rear+1)%max;  //rear始终在0-10中循环
		L->data[L->rear]=x; 
		num++;
		return true;
	}
} 
//出队
int popteam(team &L,int &x){
	if(num==0){
		printf("队空!");
		return false;
	}else{
		L->front=(L->front+1)%max;  //front始终在0-10中循环
		x=L->data[L->front];
		num--;
		printf("\n%d出队\n",x);
		return x;
	} 
}
//遍历队
void printteam(team L){
	int p;
	p=L->front+1;
	if(L->front<L->rear){
		while(p<=L->rear){
		printf("%d ",L->data[p]);
		p++;}
	}else{
		while((p-1)!=L->rear){
			printf("%d ",L->data[p]);
			p=(p+1)%max;
		}
	}
  }
//求队长 
 int teamlength(team L){
 	int p;
 	if(L->front<L->rear){
 		p=(L->rear)-(L->front);      //当队列正常时 
	 }else{
	 	p=L->rear+(max-(L->front));  //当队列开始循环时 
	 }
	printf("\n队长为:%d",p);
 }
 //取队头元素
  int gettop(team L){
  	if(L->front==L->rear){
  		printf("队空!");
  		return false;
	  }else{
	  	int t=L->data[L->front+1];
	  	return t;
	  }
  } 
  
  
  /*     
  		pushteam:入队函数	popteam:出队函数 
  		printteam:遍历函数	gettop:取队头函数 
  		Initteam:初始化函数	teamlength:求队长函数 
  */
  
  
int main(){
	team s;
	int w;
	Initteam(s);
	//1-3进队列 
	pushteam(s,1);      
	pushteam(s,2);
	pushteam(s,3);
	printf("------1-3进队列后----------\n");
	printf("此时队列为:");
	printteam(s);
   	popteam(s,w);
	popteam(s,w);
	printf("此时队列为:");
	printteam(s);
	printf("\n------4-6进队列后----------\n");
	pushteam(s,4);
	pushteam(s,5);
	pushteam(s,6);
	printf("此时队列为:");
	printteam(s);
	teamlength(s);
	int T=gettop(s);
	printf("\n队头元素为:%d",T);
}

实现结果:

总结

到此这篇关于C语言实现顺序循环队列实例的文章就介绍到这了,更多相关C语言顺序循环队列内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Qt计时器使用方法详解

    Qt计时器使用方法详解

    这篇文章为大家详细主要介绍了Qt计时器的使用方法,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-08-08
  • C/C++字符串函数之复制函数详解

    C/C++字符串函数之复制函数详解

    下面小编就为大家带来一篇C/C++字符串函数之复制函数详解。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2016-09-09
  • 关于C语言中数据在内存中的存储详解

    关于C语言中数据在内存中的存储详解

    这篇文章主要给大家介绍了关于C语言中数据在内存中的存储的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-04-04
  • 深入解析C++中的std::thread的使用

    深入解析C++中的std::thread的使用

    这篇文章主要介绍了C++中的std::thread的使用,在C++11新标准中,可以简单通过使用thread库,来管理多线程,本文通过实例代码给大家详细讲解,需要的朋友可以参考下
    2023-04-04
  • C语言实现出栈序列合法性判定

    C语言实现出栈序列合法性判定

    这篇文章主要为大家详细介绍了C语言实现出栈序列合法性判定,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-05-05
  • C语言数据结构之单向链表详解

    C语言数据结构之单向链表详解

    单向链表(单链表)是链表的一种,其特点是链表的链接方向是单向的,对链表的访问要通过顺序读取从头部开始。本文将为大家详细讲讲单向链表的实现与使用,需要的可以参考一下
    2022-08-08
  • 如何通过UltraEdit解析BMP文件内部结构(BMP位图基础)

    如何通过UltraEdit解析BMP文件内部结构(BMP位图基础)

    我们先打开画图随便画一幅图并采用24位bmp图像格式保存,就得到了一张24位真彩色的位图,下面我们来详细分析bmp位图的各个组成部分,感兴趣的朋友跟随小编一起看看吧
    2021-08-08
  • C语言实现简单猜拳小游戏

    C语言实现简单猜拳小游戏

    这篇文章主要为大家详细介绍了C语言实现简单猜拳小游戏,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-03-03
  • 嵌入式C语言二级指针在链表中的应用

    嵌入式C语言二级指针在链表中的应用

    这篇文章主要为大家介绍了嵌入式C语言二级指针在链表中的应用,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步早日升职加薪
    2022-04-04
  • C语言实现常见进制转换的示例代码

    C语言实现常见进制转换的示例代码

    生活中最常见的进制是十进制,而有一类编程题会要求将十进制转换为其他进制,本文将主要讲述C语言中常见的几类进制转换问题,希望对大家有所帮助
    2023-04-04

最新评论