队列的基本运算(顺序,环形,链式)

          以下分别介绍了顺序队列,环形队列,链式队列的基本运算。主要有五种基本运算:1.初始化队列,2.销毁队列,3.判断队列是否为空,4.进队列,5.出队。

目录

顺序队列

环形队列

链式队列

 

顺序队列与环形队列的基本运算大体上都一致,只是在队满或队空时判断条件有所差异。

顺序队列

#include <stdio.h>   
#include <malloc.h>  
//顺序队中实现队列的基本运算********************************************************8 
#define MaxSize 5  
typedef char ElemType;  
typedef struct  
{  ElemType data[MaxSize];  int front,rear;     /*队首和队尾指针*/  
} SqQueue;  //初始化顺序队列 
void InitQueue(SqQueue *&q)   
{  q=(SqQueue *)malloc (sizeof(SqQueue));  q->front=q->rear=-1;  
}  //销毁顺序队列 
void DestroyQueue(SqQueue *&q) 
{  free(q);  
}  //判断顺序队列是否为空  
bool QueueEmpty(SqQueue *q)  
{  return(q->front==q->rear);  
}  //返回队列中元素个数,也称队列长度  
int QueueLength(SqQueue *q)  
{  return (q->rear-q->front);  
}  //进队列 
bool enQueue(SqQueue *&q,ElemType e)   
{  if ((q->rear+1)%MaxSize==q->front)  //队满上溢出  return false;  q->rear++; q->data[q->rear]=e;  return true;  
}  //出队列 
bool deQueue(SqQueue *&q,ElemType &e)  
{  if (q->front==q->rear)      //队空下溢出  return false;  q->front++;e=q->data[q->front];  return true;  
}  int main()  
{  ElemType e;  SqQueue *q;  printf("(1)初始化队列q\n");  InitQueue(q);  printf("(2)依次进队列元素a,b,c\n");  if (enQueue(q,'a')==0) printf("队满,不能进队\n");  if (enQueue(q,'b')==0) printf("队满,不能进队\n");  if (enQueue(q,'c')==0) printf("队满,不能进队\n");  printf("(3)队列为%s\n",(QueueEmpty(q)?"空":"非空"));  if (deQueue(q,e)==0)  printf("队空,不能出队\n");  else  printf("(4)出队一个元素%c\n",e);  printf("(5)队列q的元素个数:%d\n",QueueLength(q));  printf("(6)依次进队列元素d,e,f\n");  if (enQueue(q,'d')==0) printf("队满,不能进队\n");  if (enQueue(q,'e')==0) printf("队满,不能进队\n");  if (enQueue(q,'f')==0) printf("队满,不能进队\n");  printf("(7)队列q的元素个数:%d\n",QueueLength(q));  printf("(8)出队列序列:");  while (!QueueEmpty(q))  {  deQueue(q,e);  printf("%c ",e);  }  printf("\n");  printf("(9)释放队列\n");  DestroyQueue(q);  return 0;  } 

环形队列

#include <stdio.h>   
#include <malloc.h>  
//环形队中实现队列的基本运算********************************************************8 
#define MaxSize 5  
typedef char ElemType;  
typedef struct  
{  ElemType data[MaxSize];  int front,rear;     /*队首和队尾指针*/  
} SqQueue;  //初始化环形队列 
void InitQueue(SqQueue *&q)   
{  q=(SqQueue *)malloc (sizeof(SqQueue));  q->front=q->rear=0;  
}  //销毁环形队列 
void DestroyQueue(SqQueue *&q) 
{  free(q);  
}  //判断环形队列是否为空  
bool QueueEmpty(SqQueue *q)  
{  return(q->front==q->rear);  
}  //返回队列中元素个数,也称队列长度  
int QueueLength(SqQueue *q)  
{  return (q->rear-q->front);  
}  //进队列 
bool enQueue(SqQueue *&q,ElemType e)   
{  if ((q->rear+1)%MaxSize==q->front)  //队满上溢出  return false;  q->rear=(q->rear+1)%MaxSize;q->data[q->rear]=e;  return true;  
}  //出队列 
bool deQueue(SqQueue *&q,ElemType &e)  
{  if (q->front==q->rear)      //队空下溢出  return false;  q->front=(q->front+1)%MaxSize; e=q->data[q->front];  return true;  
}  int main()  
{  ElemType e;  SqQueue *q;  printf("(1)初始化队列q\n");  InitQueue(q);  printf("(2)依次进队列元素a,b,c\n");  if (enQueue(q,'a')==0) printf("队满,不能进队\n");  if (enQueue(q,'b')==0) printf("队满,不能进队\n");  if (enQueue(q,'c')==0) printf("队满,不能进队\n");  printf("(3)队列为%s\n",(QueueEmpty(q)?"空":"非空"));  if (deQueue(q,e)==0)  printf("队空,不能出队\n");  else  printf("(4)出队一个元素%c\n",e);  printf("(5)队列q的元素个数:%d\n",QueueLength(q));  printf("(6)依次进队列元素d,e,f\n");  if (enQueue(q,'d')==0) printf("队满,不能进队\n");  if (enQueue(q,'e')==0) printf("队满,不能进队\n");  if (enQueue(q,'f')==0) printf("队满,不能进队\n");  printf("(7)队列q的元素个数:%d\n",QueueLength(q));  printf("(8)出队列序列:");  while (!QueueEmpty(q))  {  deQueue(q,e);  printf("%c ",e);  }  printf("\n");  printf("(9)释放队列\n");  DestroyQueue(q);  return 0;  } 

链式队列

#include <stdio.h>
#include <malloc.h>
typedef char ElemType;  
//定义结构类型 
typedef struct qnode
{ElemType data;struct qnode*next;
}DateNode;
//创建一个虚拟首节点和尾节点 
typedef struct
{DateNode *front;DateNode *rear;
}LinkQueue;//初始化队列 
void InitQueue(LinkQueue *&q)
{//链队头结点申请空间q = (LinkQueue *)malloc(sizeof(LinkQueue));//队首尾指针置空q->front = q->rear =NULL;
}//销毁队列 
void DestroyQueue(LinkQueue *&q)		//逐一消除,从首节点到尾 ,最后释放头结点 
{DateNode *pre = q->front;DateNode *p;//先判断链队是否为空,为空无需删除数据节点 ,直接释链队头结点q即可if(pre!=NULL){p=pre->next;while(p!=NULL){//当我们要删除的节点后无节点free(p);pre=p;p= p->next;}free(pre);}free(q);				//释放链队头结点 
}//判断队列是否为空 
bool QueueEmpty(LinkQueue *q)
{return(q->rear==NULL);
}//进队列 
void enQueue(LinkQueue *&q,ElemType e)
{//为新元素创建链表节点DateNode *p;p = (DateNode *)malloc(sizeof(DateNode));p->data = e;//因为新节点作为尾结点,所以后继指针置空p->next = NULL;//插入前,先判断队列是否为空,如果为空,则新元素作为唯一一个节点,//队首指针和队尾指针都指向这个节点if(q->rear == NULL){q->front = q->rear = p;}else{q->rear->next = p;q->rear = p;}}bool deQueue(LinkQueue*&q,ElemType &e)
{DateNode *t;if ((q->rear==NULL){return false;}t=q->front;if (q->front==q->rear){    q->front=q->rear=NULL;}else{q->front=q->front->next;}e=t->data;free(t);return true;}
int main()
{}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/389937.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

upload-labs靶场练习

文件上传函数的常见函数&#xff1a; 在PHP中&#xff0c;‌文件上传涉及的主要函数包括move_uploaded_file(), is_uploaded_file(), get_file_extension(), 和 mkdir()。‌这些函数共同协作&#xff0c;‌使得用户可以通过HTTP POST方法上传文件&#xff0c;‌并在服务器上保存…

pycharm安装与配置Pyqt5

pycharm安装与配置Pyqt5 1、创建项目、虚拟环境 打开pycharm&#xff0c;File->New Project 2、安装pyqt5库 在pycharm下方Terminal终端窗口输入&#xff1a; pip install PyQt5 -i https://pypi.douban.com/simple pip install PyQt5-tools -i https://pypi.douban.c…

模拟实现strcmp,判断二个字符串是否相等

1.判断二个字符串是否相等&#xff0c;可以模仿strcmp.当二个字符串相等的时候ruturn 0.,当二个字符串小于时返回为小于0&#xff0c;当二个字符串大于时返回为大于0。const为不可以更改。 //方法一 int my_strcmp(const char* arr1, const char* arr2) {assert(arr1 &&…

CFA FRM原創講義和視頻等備考全部資料內容,順便征求建議

大家好&#xff0c;我是小伯&#xff0c; 曾經我也很喜歡上這個壇子查資料&#xff0c;好多年過去&#xff0c;現在論壇蠻雕零的很感慨。我和幾個朋友原創作了一些CFA一級二級三級和FRM一級二級雙語中英文的課件、視頻、資料&#xff0c; 是我們從2024年起一起合作的一個以自學…

C语言 | Leetcode C语言题解之第316题去除重复字母

题目&#xff1a; 题解&#xff1a; char* removeDuplicateLetters(char* s) {int vis[26], num[26];memset(vis, 0, sizeof(vis));memset(num, 0, sizeof(num));int n strlen(s);for (int i 0; i < n; i) {num[s[i] - a];}char* stk malloc(sizeof(char) * 27);int stk…

算法学习day27

一、寻找重复数(链表中找环) 给定一个包含 n 1 个整数的数组 nums &#xff0c;其数字都在 [1, n] 范围内&#xff08;包括 1 和 n&#xff09;&#xff0c;可知至少存在一个重复的整数。 假设 nums 只有 一个重复的整数 &#xff0c;返回 这个重复的数 。 题意&#xff1a…

[Git][认识Git]详细讲解

目录 1.什么是仓库&#xff1f;2.认识工作区、暂存区、版本库3.认识 .git1.index2.HEAD && master3.objects4.总结 1.什么是仓库&#xff1f; 仓库&#xff1a;进⾏版本控制的⼀个⽂件⽬录 2.认识工作区、暂存区、版本库 工作区&#xff1a;在电脑上写代码或⽂件的⽬录…

Java Excel复杂表头,表头合并单元格

Java Excel复杂表头&#xff0c;表头合并单元格 效果预览 一、maven依赖 <!--操作excel --><dependency><groupId>com.alibaba</groupId><artifactId>easyexcel</artifactId><version>2.1.1</version><scope>test</…

【C++标准模版库】vector的介绍及使用

vector 一.vector的介绍二.vector的使用1.vector 构造函数2.vector 空间增长3.vector 增删查改4.vector 迭代器的使用1.正向迭代器2.反向迭代器 5.victor 迭代器失效问题&#xff08;重点&#xff09; 三.vector不支持 流提取与流插入四.vector存储自定义类型1.存储string2.存储…

大数据环境安装Elasticsearch Kibana可视化

1、用yum安装&#xff0c;配置仓库和镜像。 2、用离线软件包&#xff0c;rpm安装。 服务器环境CentOS7.9 因为云安装&#xff0c;配置镜像版本一直没有成功&#xff0c;改为直接下载软件安装。 官方网址&#xff1a;https://www.elastic.co/cn/downloads/elasticsearch 因为要…

linux用户组练习

准备工作 [rootlocalhost ~]# watch -n 1 tail -n 5 /etc/group使用watch 动态监控 1.建立用户组 shengcan&#xff0c;其id 为2000 2.建立用户组 caiwu&#xff0c;其id 为 2001 3.足建立用户组 jishu&#xff0c;其id 为 2002 4.建立用户lee&#xff0c;指定其主组id为sh…

【开源】嵌入式Linux(IMX6U)应用层综合项目(1)--云平台调试APP

目录 1.简介 1.1功能介绍 1.2技术栈介绍 1.3演示视频 1.4硬件介绍 2.软件设计 2.1连接阿里云 2.2云平台调试UI 2.3Ui_main.c界面切换处理文件 2.4.main函数 3.结尾&#xff08;附网盘链接&#xff09; 1.简介 此文章并不是教程&#xff0c;只能当作笔者的学习分享&…

江协科技51单片机学习- p31 LCD1602液晶屏驱动

&#x1f680;write in front&#x1f680; &#x1f50e;大家好&#xff0c;我是黄桃罐头&#xff0c;希望你看完之后&#xff0c;能对你有所帮助&#xff0c;不足请指正&#xff01;共同学习交流 &#x1f381;欢迎各位→点赞&#x1f44d; 收藏⭐️ 留言&#x1f4dd;​…

端到端自动驾驶:挑战与前沿

End-to-end Autonomous Driving: Challenges and Frontiers 端到端自动驾驶&#xff1a;挑战与前沿 Abstract The autonomous driving community has witnessed a rapid growth in approaches that embrace an end-to-end algorithm framework, utilizing raw sensor input …

OpenSPG安装部署

文章目录 前言一、安装前准备安装docker安装docker compose 二、安装服务端下载 docker-compose.yml 文件启动服务端 三、安装客户端拉取镜像克隆OpenSPG源码 案例 前言 OpenSPG是以SPG框架为基础设计和实现的知识图谱开放引擎&#xff0c;它为领域图谱构建提供了明确的语义表…

常见病症之中医药草一枝黄花

常见病症之中医药草一枝黄花 1. 源由2. 一枝黄花植物描述药用部分主要成分药理作用使用方法注意事项 3. 常用方剂3.1 一枝黄花汤3.2 一枝黄花解毒汤 4. 着凉感冒主要方剂加味处方使用方法注意事项 5. 补充资料 1. 源由 注&#xff1a;仅供参考&#xff0c;建议在中医师指导下使…

电商兴农,柳湖新篇:特色产品助力乡村发展

在 2024 年这个充满希望与活力的年份&#xff0c;电商兴农的热潮如同一股春风&#xff0c;吹进了柳湖这片充满生机的土地。玄鹤洞油茶、醋&#xff0c;食家巷特色传统面点、陇原雪陇强面粉、陇源香亚麻籽油等特色产品&#xff0c;以及众多农家的积极参与&#xff0c;共同书写了…

欧科云链7月安全月报 | 私钥泄露损失约占总损失88%,超2.6亿美元

7 月全网累计造成损失约 2.9 亿美元&#xff0c;因私钥泄露所造成损失占总损失的 88.31%&#xff0c;其中 WazirX 因多签钱包私钥泄露&#xff0c;造成约 2.35 亿美元的损失&#xff0c;为 7 月最大安全事件。 最大安全事件-私钥泄漏 7 月 18 日&#xff0c;WazirX 多签钱包私…

免账户免权限免费获取 A股 全市场股票ETF指数 分钟级数据

日期 2024/8/2 意外发现的&#xff0c;抛砖引玉&#xff0c;测试了下&#xff0c;其他券商的也可以。 可以直接获取 1m 5m 1day 级别的数据&#xff0c;全A股市场的都可以。期货未测试。 需要 其他的级别的分数数据可以自行合成。 原理 券商版qmt获取行情数据时&#xff0c;不…

Java 设计模式之策略模式 (Strategy Pattern) 详解

Java 设计模式之策略模式 (Strategy Pattern) 详解 策略模式&#xff08;Strategy Pattern&#xff09;是一种行为型设计模式&#xff0c;旨在定义一系列算法&#xff0c;将每个算法封装起来&#xff0c;并使它们可以互相替换&#xff0c;从而使得算法的变化不会影响使用算法的…