队列-数据结构

news/2024/9/16 7:44:50 标签: 链表, 数据结构
一、队列 FIFO

特点:先进先出,后进后出

允许从一段插入数据,另一端删除数据的线性存储结构

队尾:插入数据 入队

队头:删除数据 出队

管道实质上也是一个队列。

用途:缓存数据(主要是避免两者速度不匹配的,数据存取速度不匹配。)

二、队列类型
2.1、顺序队列

顺序队列---------》假溢出-----------------》循环队列(如果用顺序队列里面,我们主要用的就是循环队列)

队列中的假溢出是指当队列的存储空间实际上还有空闲位置时,由于队列的访问限制导致无法插入新的元素,从而表现出“溢出”的假象。在循环队列中,这种情况尤为常见。

循环队列是一种使用数组存储数据元素的线性数据结构,它利用数组的环状特性来处理队列的入队和出队操作。在循环队列中,通常有两个指针front和rear分别指向队列的第一个元素和最后一个元素的下一个位置。队列的空和满的条件是相同的,都是(rear + 1) % queueSize == front,其中queueSize是队列的容量。因此,当队列满时,即使数组中有空间,也会因为队列的规则认为它已经满了,无法再添加新元素,这时如果尝试入队,就会产生假溢出。

解决假溢出的方法

为了避免假溢出,可以在定义循环队列的时候预留一个位置,通常在初始化队列时,将front和rear都设置为0,但在判断队列满的条件中加入一个额外的判断条件,比如rear == front时队列为空,而(rear + 1) % queueSize == front时队列为满。

2.2、链式队列

1、创造队列

Queue_t *create_queue()
{
    Queue_t *queue = malloc(sizeof(Queue_t));
    if(queue == NULL)
    {
        return NULL;
    }
    queue->pfront = NULL;
    queue->prear = NULL;
    queue->clen =0;
    pthread_mutex_init(&(queue->mutex),NULL);
    return queue;
}

2、入队

int push_queue(Queue_t *queue,QDataType data)
{
    QNode_t *qnode = malloc(sizeof(QNode_t));
    if(qnode == NULL)
    {
        perror("malloc fail");
        return -1;
    }
    qnode->data = data;
    qnode->pnext = NULL;
    if(is_empty_queue(queue))
    {
        queue->prear = qnode;
        queue->pfront = qnode;
    }
    queue->prear->pnext = qnode;
    queue->prear = qnode;
    queue->clen++;
    return 0;
}

3、出队

int pop_queue(Queue_t *queue,QDataType *data)
{
    if(is_empty_queue(queue))
    {
        return 0;
    }
    QNode_t *qnode = queue->pfront;
    queue->pfront = qnode->pnext;
    if(data != NULL)
    {
        *data = qnode->data;
    }
    free(qnode);
    if(NULL == queue->pfront)
    {
        queue->prear = NULL;
    }
    queue->clen--;
    return 0;
}

4、得到队头元素

int get_queue_front(Queue_t *queue,QDataType *data)
{
    QNode_t *q = queue->pfront;
    *data = q->data;
    return 0;
}

5、清空队列

void clear_queue(Queue_t *queue)
{
    while(!is_empty_queue(queue))
    {
        pop_queue(queue,NULL);
        /*
        QNode_t *qnode = queue->pfront;
        queue->pfront = qnode->pnext;
        free(qnode);
        queue->clen--;*/
    }
}

6、销毁队列

    void destory_queue(Queue_t *queue)
{
    clear_queue(queue);
    free(queue);
}


http://www.niftyadmin.cn/n/5643383.html

相关文章

C++学习笔记----6、内存管理(一)---- 使用动态内存(1)

当你使用现代结构,例如std::vector,std::string等等,从一开始到现在以及到未来,C是一个安全的编程语言。该语言提供了许多的道路,路线以及红绿灯,比如C核心指导,静态代码分析器来分析代码的正确性&#xff…

Java设计模式【命令模式】-行为型

1. 介绍 命令模式(Command Pattern) 是一种行为型设计模式,它将一个请求封装为一个对象,从而使我们可以用不同的请求对客户端进行参数化,并且支持请求的排队、记录日志以及撤销、重做等功能。命令模式将请求的发送者与…

计算机视觉中,什么是上下文信息(contextual information)?

在计算机视觉中,上下文信息(contextual information)是指一个像素或一个小区域周围的环境或背景信息,它帮助模型理解图像中对象的相对位置、大小、形状,以及与其他对象的关系。上下文信息在图像中提供了全局的语义和结…

使用 Nacos 来管理微服务

Nacos 是阿里巴巴开源的一个易于构建云原生应用的动态服务发现、配置管理和服务管理平台。它旨在帮助开发者更轻松地构建、部署微服务架构,并且支持动态配置服务、服务发现以及服务间的健康检查等功能。 Nacos 的主要功能包括: 服务发现与健康检查&#…

从贝叶斯角度理解卡尔曼滤波算法

学完卡尔曼滤波可以说你是地球上战斗力超强的人了,因为几乎所有带电的军事装备、航空航天装备都需要卡尔曼滤波算法。 直观理解 首先卡尔曼滤波要解决的问题是什么?以我军发射一枚导弹攻击敌方某固定位置目标为例(搞技术的总要有点情怀,老是讲啥小车运动,温度计这些就太lo…

Oracle高级压缩和透明数据加密组合实验

本文参考了实验DB Security - Advanced Compression with Transparent Data Encryption(TDE),其申请地址在这里。 本文只使用了实验中关于高级压缩和在线重定义的部分。并对要点进行说明及对实验进行了简化。 准备:环境设置 原文中的实验环境实际上是…

docker基础知识-docker0网桥

文章目录 示意图Docker 网桥的工作原理Docker 网桥的优势Docker 网桥的局限性自定义网桥网络 Docker 网桥(Docker bridge network)是 Docker 默认的一种网络模式,它允许 Docker 容器之间通过一个虚拟的交换机进行通信。Docker 网桥网络为容器…

CSS学习4[重点]--标签显示模式(块级元素、行内元素、行内块标签)以及模式转换

标签显示模式 一、块级元素(block-level)二、行内元素(inline-level)三、行内块标签(inline-block)四、显示模式转换 一、块级元素(block-level) 每一个块元素通常会独自占据一行或多…