目录

  • 一、基础知识
  • 二、数组实现环队
    • 2.1 初始化
    • 2.2 判断环队是否为空
    • 2.3 判断环队是否为满
    • 2.4 入队
    • 2.5 出队
    • 2.6 取队头元素
    • 2.7 取队尾元素
    • 2.8 销毁环队
  • 三、链表实现环队
    • 3.1 初始化
    • 3.2 判断环队是否为空
    • 3.3 判断环队是否为满
    • 3.4 入队
    • 3.5 出队
    • 3.6 取队头元素
    • 3.7 取队尾元素
    • 3.8 销毁环队

一、基础知识

  • 环形队列:是首尾相连的先进后出的数据结构

  • 特点:给定空间大小

  • 应用:环形队列广泛用于网络数据收发,和不同程序间数据交换(比如内核与应用程序大量交换数据,从硬件接收大量数据)

  • 实现:① 数组环队 ② 链表环队

  • 一个严重的问题
    (1) 如何判断队为空?(2) 如何判断队为满?答案:(1)front == tail (2)front == tail
    为了区别两个判断条件的重合问题,需要在数组队/链队预留一个空间的位置
    (1) front == tail (2) (tail+1)%5 == front

二、数组实现环队

结构体

typedef struct CircularQueue
{int* arry; int front;int tail;int size;//数组大小
}CQueue;

2.1 初始化

//初始化
void CQueueInit(CQueue* cq, int k)
{assert(cq);cq->arry = (int*)malloc(sizeof(int) * (k+1));cq->front = cq->tail = 0;cq->size = k;
}

2.2 判断环队是否为空

//判断环形队列是否为空
bool CQueueIsEmpty(CQueue* cq)
{assert(cq);return cq->front == cq->tail;
}

2.3 判断环队是否为满

//判断环形队列是否为满
bool CQueueIsFull(CQueue* cq)
{assert(cq);return (cq->tail + 1) % (cq->size + 1) == cq->front;
}

2.4 入队

//入队
void CQueuePush(CQueue* cq, int x)
{assert(cq);if (CQueueIsFull(cq)){printf("队满!");exit(0);}cq->arry[cq->tail] = x;//赋值cq->tail = (cq->tail + 1) % (cq->size + 1);//tail走一步
}

2.5 出队

//出队
void CQueuePop(CQueue* cq)
{assert(cq);if (CQueueIsEmpty(cq)){printf("队空!");exit(0);}cq->front = (cq->front + 1) % (cq->size + 1);//front走一步
}

2.6 取队头元素

//取队头元素
int CQueueFront(CQueue* cq)
{assert(cq);if (CQueueIsEmpty(cq)){printf("队空!");exit(0);}return cq->arry[cq->front];
}

2.7 取队尾元素

//取队尾元素
int CQueueBack(CQueue* cq)
{assert(cq);if (CQueueIsEmpty(cq)){printf("队空!");exit(0);}int tail_i = (cq->tail + cq->size) % (cq->size + 1);//找到tail的上一个位置return cq->arry[tail_i];
}

2.8 销毁环队

//环形队列的销毁
void CQueueDestroy(CQueue* cq)
{assert(cq);free(cq->arry);free(cq);
}

“向后走”(cur+1)%(k+1)
“向前走”(cur+k)%(k+1)

三、链表实现环队

结构体

typedef int DataType;
typedef struct CQueueNode
{DataType data;CQueueNode* next;
}CQueueNode;
typedef struct CQueue
{CQueueNode* front;CQueueNode* tail;
}CQueue;

3.1 初始化

//初始化
void CQueueInit(CQueue* cq, int k)
{assert(cq);CQueueNode* plist = CreatCQueueList(k + 1);cq->front = cq->tail = plist;
}
//创建k个结点的链表
CQueueNode* CreatCQueueList(int k)
{CQueueNode* phead = NULL;CQueueNode* tail = phead;while (k){CQueueNode* newNode = (CQueueNode*)malloc(sizeof(CQueueNode));newNode->next = NULL;if (phead == NULL){phead = tail =newNode;}else{tail->next = newNode;tail = newNode;}--k;}tail->next = phead;return phead;
}

3.2 判断环队是否为空

//判断环形队列是否为空
bool CQueueIsEmpty(CQueue* cq)
{assert(cq);return cq->front == cq->tail;
}

3.3 判断环队是否为满

//判断环形队列是否为满
bool CQueueIsFull(CQueue* cq)
{assert(cq);return cq->front == cq->tail->next;
}

3.4 入队

//入队
void CQueuePush(CQueue* cq, int x)
{assert(cq);if (CQueueIsFull(cq)){printf("队满!");exit(0);}cq->tail->data = x;cq->tail = cq->tail->next;
}

3.5 出队

//出队
void CQueuePop(CQueue* cq)
{assert(cq);if (CQueueIsEmpty(cq)){printf("队空!");exit(0);}cq->front = cq->front->next;
}

3.6 取队头元素

//取队头元素
int CQueueFront(CQueue* cq)
{assert(cq);if (CQueueIsEmpty(cq)){printf("队空!");exit(0);}return cq->front->data;
}

3.7 取队尾元素

//取队尾元素
int CQueueBack(CQueue* cq)
{assert(cq);if (CQueueIsEmpty(cq)){printf("队空!");exit(0);}CQueueNode* cur = cq->front;while (cur){if (cur->next == cq->tail)break;cur = cur->next;}return cur->data;
}

3.8 销毁环队

//环形队列的销毁
void CQueueDestroy(CQueue* cq)
{assert(cq);//第一层:free链表结点CQueueNode* cur = cq->front;while (cur){CQueueNode* next = cur->next;free(cur);cur = next;}//第二层:free front和tailfree(cq);
}

【数据结构(C语言描述)】环形队列相关推荐

  1. c语言用指针求Amn,[工学]第5章数据结构C语言描述耿国华.ppt

    [工学]第5章数据结构C语言描述耿国华 j=1;  for(k=1; k<=A.n; k++)  for(i=1; i<=A.len; i++) if(A.data[i].col== ...

  2. Java版数据结构之数组模拟环形队列demo

    Java版数据结构之数组模拟环形队列demo 我的代码仓库:https://github.com/zhuangbinan/datastructure 类 CircleArray package clu ...

  3. C语言实现环形队列基本操作

    C语言实现环形队列基本操作(以简单排队问题为例) 通过调用简单函数实现顺序表的相关操作.代码编译环境为VS2019 16.9.4.因为VS的某些原因,scanf写为了scanf_s,作用是一样的,在其 ...

  4. 大学python用什么教材-数据结构 Python语言描述 大学教材

    书名:数据结构:Python语言描述 定价:69.8 ISBN:9787115485779 作者:张光河 版次:第1版 出版时间:2018-07 内容提要: Python是目前流行的程序设计语言,国内 ...

  5. c语言环形队列用法,C语言,环形队列

    什么是环形队列? 环形缓冲区是一个非常典型的数据结构,这种数据结构符合生产者,消费者模型,可以理解它是一个水坑,生产者不断的往里面灌水,消费者就不断的从里面取出水. 那就可能会有人问,既然需要灌水,又 ...

  6. 数据结构与基础算法-环形队列

    一.什么是环形队列. 其实在内存上并没有所谓的环形队列,环形队列只是基于数组线性空间来实现. 环形队列优点: 避免假溢出现象.(因为在数组里,头尾指针只增加不减少,被删元素的空间再也不能被重新利用.会 ...

  7. 算法与数据结构java语言描述 英文版_CVPR2020 |室内设计师失业?针对语言描述的自动三维场景设计算法...

    近日,计算机视觉顶会CVPR 2020接收论文结果公布,从6656篇有效投稿中录取了1470篇论文,录取率约为22%.在<Intelligent Home 3D: Automatic 3D-Ho ...

  8. python语言描述兰伯特pdf_数据结构PYTHON语言描述 [美] Kenneth A. Lambert 兰伯特

    第1章 Python编程基础 1 1.1 基本程序要素 1 1.1.1 程序和模块 1 1.1.2 Python程序示例:猜数字 1 1.1.3 编辑.编译并运行 Python程序 2 1.1.4 程 ...

  9. 数据结构c语言描述第课后答案李学刚,数据结构(C语言描述)(第2版)

    本书共有7个单元,包括:单元1 数据结构与算法.单元2 线性表.单元3 栈和队列.单元4 树与二叉树.单元5 图.单元6排序和单元7查找,每个单元由若干节次.每个节次由若干知识点构成:主要介绍了数据结 ...

最新文章

  1. IBM苏中:怎样利用深度学习、增强学习等方法提高信息处理效率
  2. 需要注意AT24Cxx和BL24Cxx引脚不一样
  3. 单片机上电复位电路图大全
  4. SpringCloud教程-服务的注册与发现Eureka(SpringCloud版本Finchley)
  5. opencv-python将视频切分成帧
  6. C语言函数题-P字符串的比较
  7. inode linux x64,又一次在64位ubuntu上安装iNode
  8. 20140120收藏夹
  9. 我们大家都知道mysql_10个mysql中select语句的简单用法
  10. 用户故事与敏捷开发方法笔记05
  11. 一道企业shell编程实战题-看看谁能快速搞定
  12. 深度学习笔记_各种激活函数总结对比
  13. 2022-03-24 windows pc和Android 手机同屏软件vysor,download网址: https://www.vysor.io/#
  14. android app wifi密码,手机WiFi密码显示APP
  15. 微信小程序的开发需要什么费用
  16. 监控和路由器不在同一个ip段_如何把二级路由器当交换机使用
  17. word文档中标题跳到表格的下方-解决方法
  18. C++实现复数矩阵求逆 matlab inv
  19. python中button对象的方法_Python cmds.shelfButton方法代码示例
  20. 韩 天峰:关于PHP程序员技术职业生涯规划

热门文章

  1. Question Retrieval with Distributed Representations and Participant Reputation in Community QA论文笔记
  2. 手把手教你solidworks重力下落物体动画制作
  3. Java面试错题集1
  4. AltiumDesigner 绘制PCB常见问题
  5. 如何用大数据进行宠物店选址要素分析
  6. 典型的计算机串行和并行总线,串行总线和并行总线的区别
  7. 基于java派大星水产商城mp4计算机毕业设计源码+系统+lw文档+mysql数据库+调试部署
  8. 4号线地铁站点列表_北京地铁4号线线路图 4号线地铁站点列表
  9. MySQL 查询最好的前/后3条
  10. 设计模式-备忘录模式-java-中文版