C语言实现循环队列基本操作

 更新时间:2021年09月24日 08:30:43   作者:似曾不相识  
这篇文章主要为大家详细介绍了C语言实现循环队列基本操作,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

循环队列依靠取模运算,实现队列中数据元素的逻辑成环操作。其相比队列的顺序存储实现,可以避免“假溢出”的问题。

头文件声明

#include <stdio.h>
#include <stdlib.h>

/*
* 循环队列实现
*/
//数据元素上限
#define MaxSize 50
//定义数据类型
typedef int ElemType;
/*结构体定义*/
typedef struct SqQueue
{
 ElemType data[MaxSize];//数组-存放数据元素
 int front, //队头指针
  rear; //队尾指针
}SqQueue;

//初始化队列
void InitQueue(SqQueue *q);
//判断队列是否为空
int EmptyQueue(SqQueue q);
//入队操作
int EnQueue(SqQueue *q,ElemType e);
//出队操作
int DeQueue(SqQueue *q,ElemType* e);
//获取队列长度
int LengthQueue(SqQueue q);
//获取队头元素
void GetHead(SqQueue q,ElemType* e);
//打印队列
void printSqQueue(SqQueue q);

函数实现

#include "SqQueue.h"

/**
 * 循环队列函数实现
 */

//初始化队列
void InitQueue(SqQueue *q){
 //队头指针-队尾指针,同时指向队首元素
 q->front=q->rear=0;
}

//判断队列是否为空
int EmptyQueue(SqQueue q){
 //队头指针和队尾指针指向同一个元素,则为空队列
 return q.front==q.rear;
}

//入队操作
int EnQueue(SqQueue *q,ElemType e){
 //判断是否队满
 if ((q->rear+1)%MaxSize==q->rear)
  return -1;
 //入队操作
 q->data[q->rear]=e;//添加数据元素-将队尾元素值置为e
 q->rear=(q->rear+1)%MaxSize;//尾指针向前移动,队尾指针++
 return 1;
}
//出队操作
int DeQueue(SqQueue *q,ElemType* e){
 //判断是否队空
 if ((q->rear+1)%MaxSize==q->front)
  return -1;
 //保存数据
 *e=q->data[q->front];
 //出队操作
 q->front=(q->front+1)%MaxSize;
 return 1;
}
//获取队列长度
int LengthQueue(SqQueue q){
 return (q.rear-q.front+MaxSize)%MaxSize;
}

//获取队头元素
void GetHead(SqQueue q,ElemType* e){
 //判断队列是否为空
 if (q.front==q.rear)
  return;
 //获取队头元素的值
 *e=q.data[q.front];
}

//打印队列
void printSqQueue(SqQueue q){
 //辅助指针
 int pIndex;
 //打印队列元素
 pIndex=q.front;
 while (pIndex<q.rear)
 {
  printf("%4d",q.data[pIndex++]);
 }
 printf("\n");
}

函数测试

#include "SqQueue.h"

int main(int argc,char** argv){
 //声明队列
 SqQueue sQueue;
 int i;
 ElemType data;
 //初始化队列
 InitQueue(&sQueue);
 //获取队头指针和队尾指针的值
 printf("frontVal=%d,rearVal=%d\n",sQueue.front,sQueue.rear);
 //判断队列是否为空
 printf("is Empty?%d\n",EmptyQueue(sQueue));
 //入队操作
 for (i=0;i<20;i++)
 {
  EnQueue(&sQueue,i+1);
 }
 //判断队列是否为空&获取队列长度
 printf("is Empty?%d,len=%d\n",EmptyQueue(sQueue),LengthQueue(sQueue));
 //打印队列元素
 printSqQueue(sQueue);
 //出队操作
 DeQueue(&sQueue,&data);
 printf("the aimed value is %d\n",data);
 //判断队列是否为空&获取队列长度
 printf("is Empty?%d,len=%d\n",EmptyQueue(sQueue),LengthQueue(sQueue));
 //打印队列元素
 printSqQueue(sQueue);
 //获取队头元素值
 GetHead(sQueue,&data);
 printf("the head value is %d\n",data);
 return 0;
}

再贴个测试结果的图:

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • C++基于hook iat改变Messagebox实例

    C++基于hook iat改变Messagebox实例

    这篇文章主要介绍了C++基于hook iat改变Messagebox的方法,以实例形式展示了针对IAT(即导入地址表)以及hook的操作,有助于深入理解Windows程序设计原理,需要的朋友可以参考下
    2014-10-10
  • C++ Qt实现一个解除文件占用小工具

    C++ Qt实现一个解除文件占用小工具

    这篇文章主要为大家详细介绍了如何利用C++ Qt实现一个解除文件占用小工具,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下
    2023-09-09
  • C语言猜凶手及类似题目的实现示例

    C语言猜凶手及类似题目的实现示例

    本文主要介绍了C语言猜凶手及类似题目的实现示例,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-01-01
  • C语言实现控制台五子棋小游戏

    C语言实现控制台五子棋小游戏

    这篇文章主要为大家详细介绍了C语言实现控制台五子棋小游戏,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-07-07
  • OpenCV实现图像背景虚化效果原理详解

    OpenCV实现图像背景虚化效果原理详解

    相信用过相机的同学都知道虚化特效,这是一种使焦点聚集在拍摄主题上,让背景变得朦胧的效果。本文将详细介绍一些这一效果的实现原理以及代码,需要的可以参考一下
    2022-03-03
  • 基于Windows C++ 应用程序通用日志组件的使用详解

    基于Windows C++ 应用程序通用日志组件的使用详解

    众所周知,在调试、跟踪和执行应用程序的过程中,程序的日志能为这些工作提供大量有价值的运行信息。因此,程序的日志对应用程序的运行、维护至关重要
    2013-05-05
  • 浅谈返回函数内部new分配的内存的引用

    浅谈返回函数内部new分配的内存的引用

    下面小编就为大家带来一篇浅谈返回函数内部new分配的内存的引用。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2016-12-12
  • 详解Qt使用QImage类实现图像基本操作

    详解Qt使用QImage类实现图像基本操作

    这篇文章主要介绍了Qt如何利用QImage类实现对图像的基本操作,包括图像显示、图像缩放、图像旋转等,感兴趣的小伙伴可以跟随小编一起动手尝试一下
    2022-06-06
  • C++ opencv图像处理使用cvtColor实现颜色转换

    C++ opencv图像处理使用cvtColor实现颜色转换

    这篇文章主要为大家介绍了C++ opencv图像处理cvtColor实现颜色转换的实现示例代码,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-05-05
  • 浅析顺序结构存储的栈

    浅析顺序结构存储的栈

    这篇文章主要介绍了顺序结构存储的栈,有需要的朋友可以参考一下
    2014-01-01

最新评论