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

数据结构(6)线性表-队列

一、队列的概述

队列也是一种特殊的线性表,只允许在一段插入数据,另一端删除数据。插入操作的一端称为队尾,删除操作的一端称为队头。

如图:

二、队列相关操作

1.队列结构体的声明

类似于栈,他肯定也得借助于数组或者是链表才能实现队列的结构体,考虑到队列的特性,我们应该考察到队尾的插入操作,队头的删除操作。

还是数组和链表两种结构作底层。

数组很明显不能胜任这个任务,数组尾部的插入和删除操作就是O(1),但是头部的插入和删除是O(n),且无法改善,所以就不用。

链表的话就说单链表,单链表由于指针的单向不循环,尾部的插入和删除操作就是O(n),头部的话可以直接通过链表指针遍历到,那就是O(1)。

看起来都不行,当然,也可以去考虑双向链表,但是这里给出一种思路:

底层数组存储的话已经是没招了,底层借助链表,归根结底就是尾部指针得遍历才能得到,所以才为O(n),那干脆我们多写一个指针呗,专门去记录尾结点的地址,方便遍历。

即,存储:

队列的结点由单链表实现,队列的特性由另外一个结构体来实现:

便于后续队尾和队头的操作。

2.初始化队列

初始化phead = ptail = NULL即可。

也就是说,底层确实是用单链表的结点实现,但是我们写函数时只用到Queue这层结构体:

测试代码:

3.入队(队尾的插入)

尾部插入很明显了:

申请个新结点先,然后

ptail->next = newnode;

ptai = ptail->next;

代码实现:

不过很明显容易出现空指针解引用问题,malloc的newnode我们确实检验过了,但是pq里面的ptail呢,换句话说,如果队列刚刚初始化,还为空的时候ptail可是NULL,所以要单独拿出来这种情况分析一下:

所以if-else一下:

测试代码:

4.出队(队头的删除)

老生常谈了,要想删除数据,首先队列不能为空:

不为空再画图去删:

再检验一下,如果只有一个结点,并且删除后,代码仍然符合吗

不为空断言肯定能通过,结果是phead置空了,符合要求,因为队列为空了,但是ptail并未处理,ptail最终指向的肯定是一块已经被释放的空间了,如果这个时候再插入,肯定就错了,所以:
if一下

代码测试:

前几次的出队正确,且如果为空可以检测出来。

5.取队头数据

先验队列不为空再取数据:

测试代码:

6..取队尾元素

基本同取队头元素:

测试:

7.取队列有效元素个数

拿着图稍微比划两下就能看出来了,让遍历指针一直走,如果不是NULL,那就++再指针后移:

测试代码:

栈和队列基础就先说这么多,后面可能还会对文章进行修改,稍加一些内容。栈和队列内容较少,较简单(建立在链表和顺序表非常熟悉的基础上),所以具体特性,实际应用就到Oj题再看。


文章转载自:
http://birdman.zekgq.cn
http://anatomic.zekgq.cn
http://cervix.zekgq.cn
http://carioca.zekgq.cn
http://cham.zekgq.cn
http://acetate.zekgq.cn
http://arguer.zekgq.cn
http://calor.zekgq.cn
http://byzantium.zekgq.cn
http://autolysin.zekgq.cn
http://bosnia.zekgq.cn
http://battered.zekgq.cn
http://abruptness.zekgq.cn
http://bandhnu.zekgq.cn
http://aonb.zekgq.cn
http://affably.zekgq.cn
http://aurochs.zekgq.cn
http://antialien.zekgq.cn
http://anear.zekgq.cn
http://autotroph.zekgq.cn
http://aluminum.zekgq.cn
http://bestiarian.zekgq.cn
http://addiction.zekgq.cn
http://burliness.zekgq.cn
http://chipboard.zekgq.cn
http://atrociously.zekgq.cn
http://chrysalides.zekgq.cn
http://bicho.zekgq.cn
http://callisthenic.zekgq.cn
http://bioglass.zekgq.cn
http://www.dtcms.com/a/208146.html

相关文章:

  • 【leetcode】3356. 零数组变换②
  • 字节跳动旗下火山引擎都覆盖哪些领域
  • 四、GPU是如何成为当前电脑中不可或缺的一部分的,opengl在其中起到了什么效果
  • 基于SpringMVC的动态时钟设计
  • youyu:91501
  • 学习黑客Nmap 是什么?
  • React从基础入门到高级实战:React 基础入门 - 简介与开发环境搭建
  • [逻辑回归]机器学习-part11
  • 相机--基础
  • Widget进阶
  • Python训练营打卡 Day25
  • 5.2.3 使用配置文件方式整合MyBatis
  • 《数据结构初阶》【八大排序——巅峰决战】
  • 【论文精读】2022 CVPR--RealBasicVSR现实世界视频超分辨率(RealWorld VSR)
  • 【Harmony OS】作业四 布局
  • Pluto实验报告——基于FM的音频信号传输并解调恢复
  • 机器学习中的维度、过拟合、降维
  • 【数据架构05】数据要素架构篇
  • 采用多维计算策略(分子动力学模拟+机器学习),显著提升 α-半乳糖苷酶热稳定性
  • SpringCloud——MybatisPlus
  • Flask 会话管理:从原理到实战,深度解析 session 机制
  • VueRouter路由组件的用法介绍
  • API自动化与持续集成核心实战知识点!
  • 从数学融智学视域系统地理解《道德经》:38至56,德化社会
  • 【ARM 嵌入式 编译系列 10.4.2 -- 查看 bss 段中有哪些内容】
  • 数据的获取与读取篇---获取数据
  • Helm简介、安装、配置、使用!
  • 极大似然估计
  • PostgreSQL 软件升级
  • 机器学习与深度学习:区别与联系