news 2026/2/23 13:37:28

顺序存储实现队列,增加额外的变量和不增加额外的变量

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
顺序存储实现队列,增加额外的变量和不增加额外的变量

(一).不增加结构体中的额外变量进行队列的实现,队列是输入输入受限的线性表,只能从一端入队,从另一端出队

1.先创建一个结构体变量,结构体创建的时候是匿名声明,然后重新更改一个名字SeqQueue,里面有两个变量,一个对头front,一个队尾指针rear,两个指针对应数组下标,出队操作只和front有关,入队和rear有关

#include<stdio.h> #define MAXSIZE 10 typedef struct { int data[MAXSIZE];//数据 int front;//front对头 int rear;//rear队尾 }SeqQueue;//queue是队列SeqQueue

2。创建一个结构体类型的变量,传递参数的时候传递指针,进行初始化函数,初始化的时候只需要将rear和front的值设置为0,同时指向下标为0元素的地方.

int InitSQueue(SeqQueue* PQ) { PQ->front = PQ->rear = 0;//对头和队尾同时指向0数组,即将插入数据的那个数组 }

3.因为初始化的时候对头元素和队尾元素指向头一个空间,所以队列判空的条件是rear和front的值相等。

int Empty(SeqQueue* PQ) { return PQ->front == PQ->rear; }

4.入队操作也就是EnQueue操作,入队之前需要判断一下队列是不是满的,因为我们判断队空的条件是rear==front,所以队满的条件就要牺牲一个存储空间使得rear+1=front,rear指向的是即将插入数据的下标,一个数组有从对头元素出队,当数组前面的数据已经是空的但是队列已经跑到最大元素的位置了,如果让其从零开始继续入队,需要Mod运算,所以队列满的情况就是(rear+1)%Max==front,牺牲了一个存储空间,另外需要注意的是,rear指的是即将插入的数据,所以再进行插入操作的时候,先插入数据,然后再让rear增加1,同时也需要模运算,使得rear从头开始继续入队

int EnQueue(SeqQueue* PQ, int elem)//EnQueue入队操作 { if ((PQ->rear + 1) % MAXSIZE == PQ->front)//浪费了个内存空间 return 1; PQ->data[PQ->rear] = elem; PQ->rear =(PQ->rear+1)%MAXSIZE;//达到逻辑上的循环队列 return 0; }

5出队操作DeQueue,由于front指的是要出队的元素,所以出队的时候先把值赋值给临时变量,再自增1,自增的同时也需要模运算,达到逻辑上的循环

int EnQueue(SeqQueue* PQ, int elem)//EnQueue入队操作 { if ((PQ->rear + 1) % MAXSIZE == PQ->front)//浪费了个内存空间 return 1; PQ->data[PQ->rear] = elem; PQ->rear =(PQ->rear+1)%MAXSIZE;//达到逻辑上的循环队列 return 0; }

6.计算队列中有几个元素,如果一个队列不是循环,那么只需要rear-front即可,我们实现的是循环队列,所以在这个基础上我们应该这样做(rear+Maxsize-front)%Maxsize,得到循环队列的元素个数,这个运算,不管rear数组下标大于front的,还是小于的都是成立的,可以朝着这个方向多想几个数据进行验证

int Len(SeqQueue* PQ) { return (PQ->rear + MAXSIZE - PQ->front) % MAXSIZE; }

(二).多一个size变量,这个变量用来记录当前队列的容量,当队列等于0时为空队列,当队列为maxsize时为最大值,这个时候不能入队,多一个变量多了很多好处,最关键的一个就是,不用浪费一个空间进行操作了,每个空间都得到的利用,而且队列当前多少元素直接返回size的值即可

1.入队操作只需要判断队的size最大值即可

int EnQueue(SeqQueue*PQ,int elem) { if (PQ->size == MAXSIZE)//等于最大的容量说明此时队列已满 return 1; PQ->data[PQ->rear] = elem;//rear指的就是即将插入数据的那个数组,先入队再加加 PQ->size += 1;//size增加一个 PQ->rear = (PQ->rear + 1) % MAXSIZE;//和没有增加条件的一样,还是要让队列达到逻辑上的循环 return 0; }

2。出队只看四则是不是等于0即可,,特别注意当等于0的时候还继续出队的话会引起下溢出

int DeQueue(SeqQueue* PQ) { if (PQ->size == 0)//说明这个时候队列没有元素不能出队,回引起下溢出 return 1; int temp = PQ->data[PQ->front]; PQ->front = (1 + PQ->front) % MAXSIZE;//同样增加的时候需要关注取模运算 return 0; }
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/2/23 5:33:06

LobeChat与FastGPT对比:两款开源聊天界面的核心差异

LobeChat 与 FastGPT 对比&#xff1a;两款开源聊天界面的核心差异 在大语言模型&#xff08;LLM&#xff09;快速普及的今天&#xff0c;越来越多开发者和企业希望将这些强大的模型融入实际业务场景。然而&#xff0c;原始模型本身并不具备用户交互能力——它更像一个“黑盒引…

作者头像 李华
网站建设 2026/2/23 0:35:41

LobeChat如何帮助初创公司低成本启动AI产品线?

LobeChat如何帮助初创公司低成本启动AI产品线&#xff1f; 在生成式AI席卷各行各业的今天&#xff0c;许多初创团队手握强大的大模型能力&#xff0c;却卡在了“如何让用户用起来”这一关。一个训练得再出色的模型&#xff0c;如果缺乏直观、稳定的交互界面&#xff0c;也难以转…

作者头像 李华
网站建设 2026/2/23 11:48:51

基于Uniapp + SpringBoot + Vue的动态个人博客系统的设计与实现

文章目录前言一、详细操作演示视频二、具体实现截图三、技术栈1.前端-Vue.js2.后端-SpringBoot3.数据库-MySQL4.系统架构-B/S四、系统测试1.系统测试概述2.系统功能测试3.系统测试结论五、项目代码参考六、数据库代码参考七、项目论文示例结语前言 &#x1f49b;博主介绍&#…

作者头像 李华
网站建设 2026/2/21 8:29:00

Conda环境管理神器:Miniconda实现多版本Python自由切换

Miniconda&#xff1a;解锁多版本 Python 自由切换的工程实践 在现代 AI 与数据科学项目中&#xff0c;一个看似简单却频繁困扰开发者的问题是&#xff1a;为什么我的代码在别人机器上跑不通&#xff1f; 答案往往藏在环境差异里——你用的是 Python 3.9&#xff0c;对方是 3.1…

作者头像 李华
网站建设 2026/2/21 3:54:52

大家好,我是田螺.分享一道网上很火的腾讯面试题:40亿的QQ号,如何去重,1G的内存. 不过,有腾讯上班的朋友说,我们没出过这种面试题~ 哈哈~哈哈,anyway,这道题还是很有意思的. 它是一

大家好,我是田螺. 分享一道网上很火的腾讯面试题:40亿的QQ号,如何去重,1G的内存. 不过,有腾讯上班的朋友说,我们没出过这种面试题~ 哈哈~ 哈哈,anyway,这道题还是很有意思的. 它是一个非常经典的海量数据去重问题,并且做了内存限制,只能1G.本文田螺哥跟大家探讨一下. 公众号&…

作者头像 李华
网站建设 2026/2/22 4:20:25

不花钱先检测论文知网AI率:很多硕士都在用这个方法

硕士小论文 AI 率偏高&#xff1f;别急&#xff0c;先用 WriterPro 免费查一查最近不少硕士同学私下交流时&#xff0c;都会提到一个共同问题&#xff1a;论文是自己一句一句写的&#xff0c;但一查 AI 率&#xff0c;却不太好看。尤其是课程论文、阶段性小论文、教学类论文&am…

作者头像 李华