数据结构(队列)

简介: 数据结构(队列)

1.队列的概念和结构

概念:队列是一种线性表,它只能从一端插入数据,从另一端删除数据,在插入数据的一端称为队头,在删除数据的一端称为队尾。队列遵循先进先出的原则。

生动形象一点就跟我们日常排队一样,先排的人先走,后排的人后走。

结构如图:

91619b6f210d4deda3d39a354515c8cc.png

2.队列的实现

队列的实现建议使用链表来实现,因为如果用数组的话出队列要调整数组,比较麻烦,而使用链表实现就可以避免这个问题。

实现过程如图:

1fb84e451a6549ada3bb41031f3860cc.png

队列的头文件:

// 链式结构:表示队列 
typedef int QDataType;
typedef struct QListNode
{
  struct QListNode* _next;
  QDataType _data;
  
}QNode;
 
// 队列的结构 
typedef struct Queue
{
  QNode* _phead;
  QNode* _ptail;
  int size;
}Queue;
 
// 初始化队列 
void QueueInit(Queue* q);
// 队尾入队列 
void QueuePush(Queue* q, QDataType data);
// 队头出队列 
void QueuePop(Queue* q);
// 获取队列头部元素 
QDataType QueueFront(Queue* q);
// 获取队列队尾元素 
QDataType QueueBack(Queue* q);
// 获取队列中有效元素个数 
int QueueSize(Queue* q);
// 检测队列是否为空,如果为空返回非零结果,如果非空返回0 
int QueueEmpty(Queue* q);
// 销毁队列 
void QueueDestroy(Queue* q);


初始化队列:

void QueueInit(Queue* q)
{
  q->_phead = q->_ptail = NULL;
  q->size = 0;
}


队尾入队列:

void QueuePush(Queue* q, QDataType data)
{
  if (q->_phead == NULL)
  {
    QNode* node = (QNode*)malloc(sizeof(QNode));
    node->_data = data;
    node->_next = NULL;
    q->_phead = q->_ptail=node;
    q->size++;
  }
  else
  {
    QNode* node = (QNode*)malloc(sizeof(QNode));
    node->_data = data;
    node->_next = NULL;
    q->_ptail->_next = node;
    q->_ptail = node;
    q->size++;
  }
}


队头出队列:

void QueuePop(Queue* q)
{
  QNode* node = q->_phead->_next;
  free(q->_phead);
  q->_phead = node;
  q->size--;
}


获取队列头部元素:

QDataType QueueFront(Queue* q)
{
  return q->_phead->_data;
}


获取队列队尾元素:

QDataType QueueBack(Queue* q)
{
  return q->_ptail->_data;
}


获取队列中有效元素个数:

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


检测队列是否为空,如果为空返回非零结果,如果非空返回0:

int QueueEmpty(Queue* q)
{
  if (q->size == 0)
    return 0;
  else
    return 1;
}


销毁队列:

void QueueDestroy(Queue* q)
{
  if (q->_phead == q->_ptail)
  {
    free(q->_phead);
    q->_phead = q->_ptail = NULL;
    q->size--;
  }
  else
  {
    QNode* node = q->_phead->_next;
    free(q->_phead);
    q->_phead = node;
    q->size--;
  }
}


目录
相关文章
|
16天前
|
C语言
【数据结构】栈和队列(c语言实现)(附源码)
本文介绍了栈和队列两种数据结构。栈是一种只能在一端进行插入和删除操作的线性表,遵循“先进后出”原则;队列则在一端插入、另一端删除,遵循“先进先出”原则。文章详细讲解了栈和队列的结构定义、方法声明及实现,并提供了完整的代码示例。栈和队列在实际应用中非常广泛,如二叉树的层序遍历和快速排序的非递归实现等。
90 9
|
1月前
|
缓存 算法 调度
数据结构之 - 双端队列数据结构详解: 从基础到实现
数据结构之 - 双端队列数据结构详解: 从基础到实现
64 5
|
1月前
|
存储 算法 搜索推荐
探索常见数据结构:数组、链表、栈、队列、树和图
探索常见数据结构:数组、链表、栈、队列、树和图
99 64
|
19天前
|
算法 安全 NoSQL
2024重生之回溯数据结构与算法系列学习之栈和队列精题汇总(10)【无论是王道考研人还是IKUN都能包会的;不然别给我家鸽鸽丢脸好嘛?】
数据结构王道第3章之IKUN和I原达人之数据结构与算法系列学习栈与队列精题详解、数据结构、C++、排序算法、java、动态规划你个小黑子;这都学不会;能不能不要给我家鸽鸽丢脸啊~除了会黑我家鸽鸽还会干嘛?!!!
|
1月前
初步认识栈和队列
初步认识栈和队列
59 10
|
1月前
|
存储 算法 定位技术
数据结构与算法学习二、稀疏数组与队列,数组模拟队列,模拟环形队列
这篇文章主要介绍了稀疏数组和队列的概念、应用实例以及如何使用数组模拟队列和环形队列的实现方法。
21 0
数据结构与算法学习二、稀疏数组与队列,数组模拟队列,模拟环形队列
|
1月前
|
存储 安全 Java
【用Java学习数据结构系列】探索栈和队列的无尽秘密
【用Java学习数据结构系列】探索栈和队列的无尽秘密
30 2
【数据结构】--- 栈和队列
【数据结构】--- 栈和队列
|
1月前
|
消息中间件 存储 Java
数据结构之 - 深入探析队列数据结构: 助你理解其原理与应用
数据结构之 - 深入探析队列数据结构: 助你理解其原理与应用
30 4
|
1月前
【初阶数据结构】深入解析队列:探索底层逻辑
【初阶数据结构】深入解析队列:探索底层逻辑