【数据结构】栈和队列(队列的基本操作和基础知识)

简介: 【数据结构】栈和队列(队列的基本操作和基础知识)

队列

队列的概念和结构

image.png

队列的实现

队列也有数组队列和链式队列。队列的特点是先进先出。实现时,数组队列,不适合头删。双向链表需要多个指针,因此,这里选择使用单链表实现。

单链表队列的实现

总的声明

typedef int QDataType;
typedef struct QueueNode
{
   
       
    QDataType val;
    struct QueueNode* next;
}QNode;

typedef struct Queue
{
   
   
    QNode* phead;
    QNode* ptail;
    int size;
}Queue;


void QueueInit(Queue* pq);
void QueueDestroy(Queue* pq);
void QueuePush(Queue* pq, QDataType x);
void QueuePop(Queue* pq);
QDataType QueueFront(Queue* pq);
QDataType QueueBack(Queue* pq);
bool QueueEmpty(Queue* pq);
int    QueueSize(Queue* pq);

初始化

image.png
上方的Push函数是有问题的,因为队列的特点是队尾进,队头出。所以插入时是尾插,单链表不好找队尾,就需要一个指向队尾的指针。因为我们的单链表是不带头节点的, 所以传一级指针也是有问题的。

解决方法:
image.png
我们将两个一级指针都放在结构体中,传参时传这个结构体指针,这样只需要传一级指针。因为改变phead和ptail时,我们改的是结构体的内容,传结构体指针即可。

下方是初始化代码:


void QueueInit(Queue* pq)
{
   
   
    assert(pq);
    pq->phead = pq->ptail = NULL;
    pq->size = 0;
}

销毁


void QueueDestroy(Queue* pq)
{
   
   
    assert(pq);
    QNode* cur = pq->phead;
    while (cur)
    {
   
   
        QNode* next = cur->next;
        free(cur);
        cur = next;
    }
    pq->phead = pq->ptail = NULL;
    pq->size = 0;
}

插入


void QueuePush(Queue* pq, QDataType x)
{
   
   
    assert(pq);
    QNode* newnode = (QNode*)malloc(sizeof(QNode));
    if (newnode == NULL)
    {
   
   
        perror("malloc fail");
        return;
    }
    newnode->val = x;
    newnode->next = NULL;

    if (pq->ptail == NULL)
    {
   
   
        pq->ptail = pq->phead = newnode;
    }
    else
    {
   
   
        pq->ptail->next = newnode;
        pq->ptail = newnode;
    }
    pq->size++;
}

删除


void QueuePop(Queue* pq) 
{
   
   
    assert(pq);
    assert(pq->phead);

    QNode* del = pq->phead;
    pq->phead = pq->phead->next;
    free(del);
    del = NULL;
    if (pq->phead == NULL)
    {
   
   
        pq->ptail = NULL;    
    }
    pq->size--;
}

取队头


QDataType QueueFront(Queue* pq)
{
   
   
    assert(pq);
    assert(pq->phead);
    return pq->phead->val;
}

取队尾


QDataType QueueBack(Queue* pq)
{
   
   
    assert(pq);
    assert(pq->ptail);
    return pq->ptail->val;
}

判断是否为空


bool QueueEmpty(Queue* pq)
{
   
   
    assert(pq);
    return pq->phead == NULL;
}

返回队列数据个数


int    QueueSize(Queue* pq)
{
   
   
    assert(pq);
    return pq->size;
}

队列的一对一关系

队列的特点是先进先出,与栈不同。入队的顺序只有一种,出队的顺序也只有一种。

目录
相关文章
|
2天前
|
存储
栈与队列练习题
栈与队列练习题
|
2天前
|
存储 索引
操作数栈的字节码指令执行分析
操作数栈的字节码指令执行分析
|
2天前
|
算法 C++
D1. Range Sorting (Easy Version)(单调栈+思维)
D1. Range Sorting (Easy Version)(单调栈+思维)
|
2天前
|
人工智能
线段树最大连续子段板子😂单调栈
线段树最大连续子段板子😂单调栈
|
2天前
数据结构第四课 -----线性表之队列
数据结构第四课 -----线性表之队列
|
2天前
数据结构第四课 -----线性表之栈
数据结构第四课 -----线性表之栈
|
3天前
|
存储
栈数据结构详解
栈(stack)是一种线性数据结构,栈中的元素只能先入后出(First In Last Out,简称FILO)。最早进入的元素存放的位置叫作栈底(bottom),最后进入的元素存放的位置叫作栈顶 (top)。本文是对堆结构的通透介绍
|
3天前
|
存储 Java
数据结构奇妙旅程之栈和队列
数据结构奇妙旅程之栈和队列
|
4天前
|
算法
栈刷题记(二-用栈操作构建数组)
栈刷题记(二-用栈操作构建数组)
|
4天前
栈刷题记(一-有效的括号)
栈刷题记(一-有效的括号)
栈刷题记(一-有效的括号)