当前位置: 首页 > news >正文

线性表之队列

  • 队列是限制在两端进行插入操作和删除操作的线性表
  • 允许进行存入操作的一端称为“队尾”允许进行删除操作的一端称为“队头”
  • 当线性表中没有元素时,称为“空队”
  • 特点 :先进先出(FIFO)或后进后出

  • 普通队列的缺点:
    • 出队后前面的空间无法重用,会造成“假溢出”
    • 当 sq->front > 0 且 sq->rear == N 时,虽然数组前面有空位,但队列已满
  • 在实际应用中,循环队列是更高效的选择,因为它避免了元素的移动,空间利用率更高。
  • 普通队列的主要缺点是空间浪费或需要移动元素的开销
  • 功能实现
#include<stdio.h>#include<stdlib.h>#include<string.h>sequeue*queue_create(){sequeue*sq;if((sq=(sequeue*)malloc(sizeof(sequeue)))==NULL){printf("malloc failed\n");returnNULL;}memset(sq->data,0,sizeof(sq->data));sq->front=sq->rear=0;returnsq;}intenqueue(sequeue*sq,datatype x){if(sq==NULL){printf("sq is NULL\n");return-1;}if(sq->rear==N){printf("sequeue is full\n");return-1;}sq->data[sq->rear]=x;sq->rear++;return0;}datatypedequeue(sequeue*sq){datatype ret;if(sq==NULL||sq->front==sq->rear){printf("queue is empty or NULL\n");return(datatype)-1;}ret=sq->data[sq->front];sq->front++;// 可选:当队列为空时,重置指针以重用空间if(sq->front==sq->rear){sq->front=sq->rear=0;}returnret;}intqueue_empty(sequeue*sq){if(sq==NULL){printf("sq is NULL\n");return-1;}return(sq->front==sq->rear?1:0);}intqueue_full(sequeue*sq){if(sq==NULL){printf("sq is NULL\n");return-1;}return(sq->rear==N?1:0);}intqueue_clear(sequeue*sq){if(sq==NULL){printf("sq is NULL\n");return-1;}sq->front=sq->rear=0;return0;}sequeue*queue_free(sequeue*sq){if(sq==NULL){printf("sq is NULL\n");returnNULL;}free(sq);returnNULL;}intqueue_length(sequeue*sq){if(sq==NULL){return-1;}returnsq->rear-sq->front;}
  • 头文件
#defineN100// 队列最大容量typedefintdatatype;// 数据类型typedefstruct{datatype data[N];// 存储队列元素intfront;// 队头指针intrear;// 队尾指针}sequeue;sequeue*queue_create();intenqueue(sequeue*sq,datatype x);datatypedequeue(sequeue*sq);intqueue_empty(sequeue*sq);intqueue_full(sequeue*sq);intqueue_clear(sequeue*sq);sequeue*queue_free(sequeue*sq);intqueue_length(sequeue*sq);
  • 测试文件
#include<stdio.h>#include"sequeue.h"intmain(intargc,constchar*argv[]){sequeue*sq;if((sq=queue_create())==NULL){return-1;}enqueue(sq,10);enqueue(sq,100);enqueue(sq,1000);while(!queue_empty(sq)){printf("dequeue:%d\n",dequeue(sq));}queue_free(sq);return0;}
http://www.jsqmd.com/news/96092/

相关文章:

  • 3、Bash 脚本编写:基础与实践
  • 轨迹规划学习记录 —— Optimal Boundary Value Problem (OBVP)
  • 交通信号仿真软件:Vistro_(4).交通网络建模
  • AXI-A7.4.6 Atomic transaction signaling
  • AI智能体:未来人机协作的核心技术解析
  • AXI-A7.4.7 Transaction structure
  • 交通信号仿真软件:Vistro_(5).交通流仿真设置
  • 4、创建交互式脚本指南
  • 交通信号仿真软件:Vistro_(6).交通信号配时优化
  • 交通信号仿真软件:Vistro_(1).Vistro软件介绍
  • 交通信号仿真软件:Vistro_(3).Vistro用户界面与基本操作
  • 交通信号仿真软件:Synchro_(14).Synchro与其他软件的集成
  • AutoGPT在智能家居控制中的应用设想:语音指令到动作执行的链路打通
  • ComfyUI插件生态盘点:提升效率的必备扩展推荐
  • ComfyUI与Skopeo镜像复制集成:跨仓库迁移
  • 17、人机工业物联网系统集成:设计与评估方法
  • 18、工业人机物理系统集成的数字化与控制评估
  • 微软将影响在线服务的第三方漏洞纳入奖励计划
  • 2025 Web 安全就业全景指南:四阶段零基础进阶路径 + 岗位适配清单,一文掌握拿 offer 技巧
  • 交通信号仿真软件:Vistro_(11).Vistro高级功能与技巧
  • 交通信号仿真软件:Vistro_(12).交通信号仿真案例研究
  • 交通信号仿真软件:Vistro_(13).Vistro与其他交通软件的集成
  • 交通信号仿真软件:Vistro_(14).交通仿真在城市规划中的应用
  • 29、工业信息物理系统的教学与学习:经验与最佳实践
  • 21、工业信息物理系统对全球互联物流的影响
  • 【教程4>第10章>第6节】基于FPGA的图像高斯滤波开发——理论分析与matlab仿真
  • 23、工业网络物理系统对交通和建筑行业的影响
  • 24、工业网络物理系统(ICPS)对建筑行业的影响
  • 三步掌握WVP-GB28181-Pro视频监控平台:从部署到性能调优全流程
  • 25、工业信息物理系统数字化与控制及其对建筑和医疗行业的影响