追梦之旅【数据结构篇】——详解C语言实现链队列

简介: 详解C语言实现链队列~😎前言🙌整体实现内容分析💞预备小知识🙌1.链队列头文件编写🙌2.链队列功能文件(Queue.c )编写:🙌1)初始化函数实现2)销毁函数实现3)队尾插入元素函数实现4)队头删除元素函数实现5)获取队头元素函数实现6)获取队尾元素函数实现7)获取队列元素个数的函数实现8)判空函数实现3.链队列测试文件编写🙌总结撒花💞

微信图片_20230427214238.gif

😎博客昵称:博客小梦

😊最喜欢的座右铭:全神贯注的上吧!!!

😊作者简介:一名热爱C/C++,算法等技术、喜爱运动、热爱K歌、敢于追梦的小博主!

😘博主小留言:哈喽!😄各位CSDN的uu们,我是你的博客好友小梦,希望我的文章可以给您带来一定的帮助,话不多说,文章推上!欢迎大家在评论区唠嗑指正,觉得好的话别忘了一键三连哦!😘

微信图片_20230427160707.gif


前言🙌



   哈喽各位友友们😊,我今天又学到了很多有趣的知识,现在迫不及待的想和大家分享一下!😘我仅已此文,手把手带领大家详解C语言实现链队列~ 结合链表的相关算法,根据队列先进先出的结构特点,实现我们链队列。都是精华内容,可不要错过哟!!!😍😍😍


整体实现内容分析💞


首先先编写我们的Queue.h文件的内容,将需要的头文件和需要实现的功能函数做个声明。然后是Queue.c文件的编写,主要是针对各个功能函数的一一实现,最后是Test.c文件的编写,测试我们功能函数是否有问题。


预备小知识🙌


队列也可以数组和链表的结构实现,使用链表的结构实现更优一些,因为如果使用数组的结构,出队列在数组头上出数据,效率会比较低。


队列的结构示意图:

微信图片_20230428140605.png


1.链队列头文件编写🙌


头文件的编写的整体思路分析:

这里是有关头文件的编写和各种功能函数的声明,首先用typedef关键字给存储数据类型取别名,这样做的好处是以后想要改变队列的数据类型只需修改typedef int QDataType;里的int即可。定义一个结构体,包括next指针和data。然后是各个功能函数声明

#pragma once
#include<stdio.h>
#include<stdlib.h>
#include<assert.h>
#include<stdbool.h>
typedef int QDataType;
typedef struct QueueNode
{
  struct QueueNode* next;
  QDataType data;
}QNode;
typedef struct Queue
{
  QNode* head;
  QNode* tail;
}Queue;
//初始化
void QueueInit(Queue* pq);
//销毁
void QueueDestory(Queue* pq);
//队尾入
void QueuePush(Queue* pq, QDataType);
//队头出
void QueuePop(Queue* pq);
//队头元素
QDataType QueueFront(Queue* pq);
//队尾元素
QDataType QueueBack(Queue* pq);
//队列元素个数
int QueueSize(Queue* pq);
//判空
bool QueueEmpty(Queue* pq);


2.链队列功能文件(Queue.c )编写:🙌


1)初始化函数实现


编写的整体思路分析:

先用assert确保pq指针的有效性,然头尾指针置为空。

//初始化
void QueueInit(Queue* pq)
{
  assert(pq);
  pq->head = pq->tail = NULL;
}


2)销毁函数实现


编写的整体思路分析:

先用assert确保pq指针的有效性,先定义一个指针cur记录head指针的位置,然后用while循环进行一个个删除:先定义一个next指向cur指针指向的下一个队列元素,然后删掉cur指向的元素,再让cur移动到下一个。

//销毁
void QueueDestory(Queue* pq)
{
  assert(pq);
  QNode* cur = pq->head;
  while (cur)
  {
    QNode* next = cur->next;
    free(cur);
    cur = next;
  }
  pq->head = pq->tail = NULL;
}


3)队尾插入元素函数实现


编写的整体思路分析:

先用assert确保pq指针的有效性,用malloc函数申请空间,用if语句来判断空间是否开辟失败。然后让newnode->next置为空,把数据放进去。如果是一开始时为空的,则让pq->head = pq->tail = newnode;如果不为空,则让之前的tail指向的节点与新节点相连。

//队尾入
void QueuePush(Queue* pq, QDataType x)
{
  assert(pq);
  QNode* newnode = (QNode*)malloc(sizeof(QNode));
  if (newnode == NULL)
  {
    printf("malloc fail\n");
    exit(-1);
  }
  newnode->data = x;
  newnode->next = NULL;
  if (pq->tail == NULL)
  {
    pq->head = pq->tail = newnode;
  }
  else
  {
    pq->tail->next = newnode;
    pq->tail = newnode;


4)队头删除元素函数实现


编写的整体思路分析:

用assert确保pq指针的有效性,如果队列为空,就不用进行队头出的操作,如果执行则报错。先用next指针指向首结点的下一个节点 。然后删掉首节点,再让head指针指向next位置。删完后,将尾指针置为NULL

//队头出
void QueuePop(Queue* pq)
{
  assert(pq);
  assert(!QueueEmpty(pq));
  QNode* next = pq->head->next;
  free(pq->head);
  pq->head = next;
  if (pq->head == NULL)
  {
    pq->tail = NULL;
  }
}


5)获取队头元素函数实现


编写的整体思路分析:

先用assert确保pq指针的有效性,如果队列为空,就不用进行此操作。然后直接返回首节点数据即可。

//队头元素
QDataType QueueFront(Queue* pq)
{
  assert(pq);
  assert(!QueueEmpty(pq));
  return pq->head->data;
}


6)获取队尾元素函数实现


编写的整体思路分析:

先用assert确保pq指针的有效性,如果队列为空,就不用进行此操作。然后直接返回尾节点数据即可。

//队尾元素
QDataType QueueBack(Queue* pq)
{
  assert(pq);
  assert(!QueueEmpty(pq));
  return pq->tail->data;
}


7)获取队列元素个数的函数实现


编写的整体思路分析:

先用assert确保pq指针的有效性,定义cur指向head的位置。利用while循环,先让Size加1,然后让cur指向下一个,知道cur为空时结束循环,返回Size大小就是队列元素的个数。

//队列元素个数
int QueueSize(Queue* pq)
{
  assert(pq);
  int Size = 0;
  QNode* cur = pq->head;
  while (cur)
  {
    Size++;
    cur = cur->next;
    return Size;
  }
}


8)判空函数实现


编写的整体思路分析:

先用assert确保pq指针的有效性,然后pq->head == NULL为真,则返回1,为假则返回0;

//判空
bool QueueEmpty(Queue* pq)
{
  assert(pq);
  return pq->head == NULL;
}


3.链队列测试文件编写🙌


(3)Tese.c文件的编写。
#define _CRT_SECURE_NO_WARNINGS 1
#include"Queue.h"
void test()
{
  Queue q;
  QueueInit(&q);
  QueuePush(&q, 1);
  QueuePush(&q, 2);
  QueuePush(&q, 3);
  QueuePush(&q, 4);
  printf("队首元素:%d\n", QueueFront(&q));
  printf("队尾元素:%d\n", QueueBack(&q));
  printf("队列元素的个数:%d\n", QueueBack(&q));
  printf("队列元素输出:");
  while (!QueueEmpty(&q))
  {
    QDataType* front = QueueFront(&q);
    printf("%d", front);
    QueuePop(&q);
  }
  printf("\n");
  QueueDestory(&q);
}
int main()
{
  test();
  return 0;
}


功能测试结果展示图:

微信图片_20230428141403.png


总结撒花💞


本篇文章旨在分享详解C语言实现链队列。希望大家通过阅读此文有所收获!本次关于队列的实现相对于之前链表和顺序表的实现简单一点,实现起来的算法和之前的栈是相似的,但结构特点与栈是相反的。指针的指向没有那么复杂,主要是对入队列和出队列的功能实现。但也有很多地方需要注意的。比如说,野指针的问题,动态开辟的空间一定要free掉,并且把指针置为NULL。用动态实现,相对于静态实现还比较灵活,也能对空间有很大的节省。

  😘如果我写的有什么不好之处,请在文章下方给出你宝贵的意见😊。如果觉得我写的好的话请点个赞赞和关注哦~😘😘😘


相关文章
|
14天前
|
C语言
【数据结构】栈和队列(c语言实现)(附源码)
本文介绍了栈和队列两种数据结构。栈是一种只能在一端进行插入和删除操作的线性表,遵循“先进后出”原则;队列则在一端插入、另一端删除,遵循“先进先出”原则。文章详细讲解了栈和队列的结构定义、方法声明及实现,并提供了完整的代码示例。栈和队列在实际应用中非常广泛,如二叉树的层序遍历和快速排序的非递归实现等。
90 9
|
13天前
|
存储 搜索推荐 算法
【数据结构】树型结构详解 + 堆的实现(c语言)(附源码)
本文介绍了树和二叉树的基本概念及结构,重点讲解了堆这一重要的数据结构。堆是一种特殊的完全二叉树,常用于实现优先队列和高效的排序算法(如堆排序)。文章详细描述了堆的性质、存储方式及其实现方法,包括插入、删除和取堆顶数据等操作的具体实现。通过这些内容,读者可以全面了解堆的原理和应用。
56 16
|
13天前
|
C语言
【数据结构】二叉树(c语言)(附源码)
本文介绍了如何使用链式结构实现二叉树的基本功能,包括前序、中序、后序和层序遍历,统计节点个数和树的高度,查找节点,判断是否为完全二叉树,以及销毁二叉树。通过手动创建一棵二叉树,详细讲解了每个功能的实现方法和代码示例,帮助读者深入理解递归和数据结构的应用。
62 8
|
16天前
|
存储 C语言
【数据结构】手把手教你单链表(c语言)(附源码)
本文介绍了单链表的基本概念、结构定义及其实现方法。单链表是一种内存地址不连续但逻辑顺序连续的数据结构,每个节点包含数据域和指针域。文章详细讲解了单链表的常见操作,如头插、尾插、头删、尾删、查找、指定位置插入和删除等,并提供了完整的C语言代码示例。通过学习单链表,可以更好地理解数据结构的底层逻辑,提高编程能力。
44 4
|
16天前
|
C语言
【数据结构】双向带头循环链表(c语言)(附源码)
本文介绍了双向带头循环链表的概念和实现。双向带头循环链表具有三个关键点:双向、带头和循环。与单链表相比,它的头插、尾插、头删、尾删等操作的时间复杂度均为O(1),提高了运行效率。文章详细讲解了链表的结构定义、方法声明和实现,包括创建新节点、初始化、打印、判断是否为空、插入和删除节点等操作。最后提供了完整的代码示例。
37 0
|
5天前
|
存储 算法
非递归实现后序遍历时,如何避免栈溢出?
后序遍历的递归实现和非递归实现各有优缺点,在实际应用中需要根据具体的问题需求、二叉树的特点以及性能和空间的限制等因素来选择合适的实现方式。
14 1
|
8天前
|
存储 算法 Java
数据结构的栈
栈作为一种简单而高效的数据结构,在计算机科学和软件开发中有着广泛的应用。通过合理地使用栈,可以有效地解决许多与数据存储和操作相关的问题。
|
11天前
|
存储 JavaScript 前端开发
执行上下文和执行栈
执行上下文是JavaScript运行代码时的环境,每个执行上下文都有自己的变量对象、作用域链和this值。执行栈用于管理函数调用,每当调用一个函数,就会在栈中添加一个新的执行上下文。
|
13天前
|
存储
系统调用处理程序在内核栈中保存了哪些上下文信息?
【10月更文挑战第29天】系统调用处理程序在内核栈中保存的这些上下文信息对于保证系统调用的正确执行和用户程序的正常恢复至关重要。通过准确地保存和恢复这些信息,操作系统能够实现用户模式和内核模式之间的无缝切换,为用户程序提供稳定、可靠的系统服务。
40 4
|
1月前
|
算法 程序员 索引
数据结构与算法学习七:栈、数组模拟栈、单链表模拟栈、栈应用实例 实现 综合计算器
栈的基本概念、应用场景以及如何使用数组和单链表模拟栈,并展示了如何利用栈和中缀表达式实现一个综合计算器。
30 1
数据结构与算法学习七:栈、数组模拟栈、单链表模拟栈、栈应用实例 实现 综合计算器

热门文章

最新文章