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

【数据结构】顺序队列模拟实现

在这里插入图片描述

💐 🌸 🌷 🍀 🌹 🌻 🌺 🍁 🍃 🍂 🌿 🍄🍝 🍛 🍤
📃个人主页 :阿然成长日记 👈点击可跳转
📆 个人专栏: 🔹数据结构与算法🔹C语言进阶
🚩 不能则学,不知则问,耻于问人,决无长进
🍭 🍯 🍎 🍏 🍊 🍋 🍒 🍇 🍉 🍓 🍑 🍈 🍌 🍐 🍍

文章目录

  • 一、队列的定义:
  • 二、链式结构队列的模拟实现
    • 1.结构图;
    • 2.队列的结构体
    • 3.初始化
    • 4.销毁队列
    • 5.入队(尾插)
    • 6.出队(头删)
    • 7.获取队头
    • 8.获取队尾
    • 9.判断是否为空
    • 10.获取队列长度

一、队列的定义:

一、队列的基本概念

队列(queue)是只允许在一端进行插入操作,而在另一端进行删除操作的线性表。 队列是一种先进先出 (First In FirstOut)的线性表,简称FIFO。允许插入的一端称为队尾,允许删除的一端称为队头

在这里插入图片描述

二、链式结构队列的模拟实现

1.结构图;

使用单向链表
在这里插入图片描述
初始状态:(队空条件):Q->front == Q->rear == 0。
进队操作:队不满时,先送值到队尾元素,再将队尾指针加1。
出队操作:队不空时,先取队头元素值,再将队头指针加1。

2.队列的结构体

在这里我使用的是单链表的形式来模拟队列。

//定义data数据类型
typedef int QueueDataType;//定义节点
typedef struct QueueNode
{struct QueueNode* next;QueueDataType data;
}QNode;//定义队列
typedef struct QueueList
{//头指针QNode* head;//尾指针QNode* tail;//链表长度int size;
}QList;

3.初始化

在这里插入图片描述

这里没有设置头节点,初始化时,两个指针都指向空。

//初始化
void QueueInit(QList* p)
{assert(p);p->head = p->tail = NULL;p->size = 0;
}

4.销毁队列

需要注意 由于动态分配的内存空间 ,在使用完队列之后,要把申请的空间及时的释放掉。具体做法就是遍历单链表,释放每一个节点。的遍历每一个节点,并对节点进行释放

//销毁队列
void QueueDestroy(QList* p)
{assert(p);QNode* cur = p->head;while (cur){QNode* next = cur->next;free(cur);cur = cur->next; }p->head = p->tail = NULL;p->size = 0; 
}

5.入队(尾插)

在这里插入图片描述

注意为空时的插入,与存在节点时,分情况讨论

//入队(尾插)
void QueuePush(QList* p, QueueDataType x)
{assert(p);QNode* newnode = (QNode*)malloc(sizeof(QNode));if (newnode == NULL){perror("malloc fail\n");exit(-1);}newnode->data = x;newnode->next = NULL;if (p->head == NULL){p->head = p->tail = newnode;}else{p->tail->next = newnode;p->tail = p->tail->next;}p->size++;
}

6.出队(头删)

在这里插入图片描述

//出队(头删)
void QueuePop(QList* p)
{assert(p);assert(!IsEmpty(p));//当只有一个节点时 if (p->head->next == NULL){free(p->head);p->head = p->tail = NULL;}//当有两个或两个以上节点else{QNode* phead = p->head->next;free(p->head);p->head->next = phead;}p->size--;
}

7.获取队头

//获取队头
QueueDataType QueueHead(QList* p)
{assert(p);assert(!IsEmpty(p));return p->head->data;
}

8.获取队尾

//获取队尾
QueueDataType QueueTail(QList* p)
{assert(p);assert(!IsEmpty(p));return p->tail->data;
}

9.判断是否为空

//判断是否为空
bool IsEmpty(QList* p)
{assert(p);return p->head == NULL;
}

10.获取队列长度

//获取队列长度
int QueueSize(QList* p)
{return p->size;
}
http://www.lryc.cn/news/126533.html

相关文章:

  • TiDB数据库从入门到精通系列之六:使用 TiCDC 将 TiDB 的数据同步到 Apache Kafka
  • Spring对象装配
  • bigemap如何添加mapbox地图?
  • python爬虫6:lxml库
  • Linux查找命令
  • 在 IntelliJ IDEA 中使用 Docker 开发指南
  • 【并发编程】自研数据同步工具的优化:创建线程池多线程异步去分页调用其他服务接口获取海量数据
  • python函数、运算符等简单介绍3(无顺序)
  • TCP服务器(套接字通信)
  • 【智慧工地源码】:人工智能、BIM技术、机器学习在智慧工地的应用
  • 使用python读Excel文件并写入另一个xls模版
  • 债务人去世,债权人要求其妻女承担还款责任,法院支持吗
  • arcgis pro3.0-3.0.1-3.0.2安装教程大全及安装包下载
  • @RequestHeader使用
  • LabVIEW开发图像采集和基于颜色的隔离
  • 站长公益主机,免费主机➕免费域名➕博客申请➕论坛申请
  • 【PRO-UPDATE】自动更新程序图形小记
  • flume系列之:监控Systemctl托管的flume agent组
  • 16.3.1 【Linux】程序的观察
  • HarmonyOS 设置全屏NoTitleBar
  • Java 模块解耦的设计策略
  • 支持https访问
  • JavaScript 中常用简写技巧总结
  • 第15集丨Vue 江湖 —— 组件
  • 【JVM】CPU飙高排查方案与思路
  • 使用公网访问内网IIS网站服务器【无需公网IP】
  • Vim学习(二)—— 编译C程序
  • 【maven】常见命令
  • vue单项数据传输流式回复功能,post传值可关闭请求(@microsoft/fetch-event-source)
  • “深入探究JVM内部机制:理解Java虚拟机的工作原理“