C语言实现链队列基本操作

 更新时间:2021年09月23日 16:19:00   作者:似曾不相识  
这篇文章主要为大家详细介绍了C语言实现链队列基本操作,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

队列的链式存储结构实现,相比于循环队列实现要复杂一些,但是没有队满的限制。

头文件声明

#include <stdio.h>
#include <stdlib.h>

/**
 * 队列的链式存储实现
 * [带头结点的单链表]
 * [-类似于链栈,队列的链式存储实现也不会出现队满的情况]
 */
//数据类型
typedef int ElemType;

//定义节点
typedef struct SqQueueNode
{
 ElemType data;//数据域
 struct SqQueueNode* next; //指针域
}SqQueueNode;
//定义队列
typedef struct SqQueueLink{
 SqQueueNode* front;//队头指针
 SqQueueNode* rear;//队尾指针
}SqQueueLink;

//初始化队列
void InitQueueLink(SqQueueLink* q);
//判断队空
int EmptyQueueLink(SqQueueLink q);
//入队操作
void EnQueueLink(SqQueueLink *q,ElemType e);
//出队操作
void DeQueueLink(SqQueueLink q,ElemType *e);
//获取队列长度
int LengthQueueLink(SqQueueLink q);
//打印队列
void printSqQueueLink(SqQueueLink q);
//获取队头元素
void GetHeadLink(SqQueueLink q,ElemType* e);

函数实现

#include "SqQueueLink.h"


//初始化队列
void InitQueueLink(SqQueueLink* q){
 //创建头结点
 SqQueueNode* pNode=(SqQueueNode*)malloc(sizeof(SqQueueNode));
 pNode->next=NULL;//指针域置空[数据域不存储任何内容]
 //初始化队列-[使队头指针和队尾指针指向头结点]
 q->front=pNode;
 q->rear=pNode;
}

//判断队空
int EmptyQueueLink(SqQueueLink q){
 return q.front==q.rear;
}

//入队操作
void EnQueueLink(SqQueueLink *q,ElemType e){
 //创建新的数据元素节点
 SqQueueNode* newNode=(SqQueueNode*)malloc(sizeof(SqQueueNode));
 newNode->data=e;//指定数据域
 newNode->next=NULL;//指针域置空
 //入队操作[从队尾入队]
 q->rear->next=newNode;
 q->rear=newNode;
}

//出队操作
void DeQueueLink(SqQueueLink q,ElemType *e){
 //[从队头出队]
 SqQueueNode* p=NULL;
 //是否队空
 if (q.front==q.rear)
  return;
 p=q.front->next;//获取首节点
 *e=p->data;
 //使队头指针指向下一节点
 q.front->next=p->next;
 //如果原队列中只有一个节点,要将队尾指针和队头指针均指向同一节点-置空
 if (q.rear==p)
  q.rear=q.front;
 //释放原首节点
 free(p);
}

//获取队列长度
int LengthQueueLink(SqQueueLink q){
 //辅助指针
 SqQueueNode* pNode=q.front->next;
 int count=0;
 //获取队列长度
 while (pNode!=q.rear)
 {
  count++;
  pNode=pNode->next;
 }
 return count;
}

//打印队列
void printSqQueueLink(SqQueueLink q){
 //辅助指针
 SqQueueNode* p=q.front->next;
 while (p!=q.rear)
 {
  printf("%4d",p->data);
  p=p->next;
 }
 printf("\n");
}

//获取队头元素
void GetHeadLink(SqQueueLink q,ElemType* e){
 //判断队列是否为空
 if (q.front==q.rear)
  return;
 //获取队头元素的值
 *e=q.front->next->data;
}

函数测试

#include "SqQueueLink.h"

int main(int argc,char** argv){
 //声明队列
 SqQueueLink sqLink;
 int i;
 ElemType data;
 //初始化队列
 InitQueueLink(&sqLink);
 //判断队列是否为空
 printf("is Empty?%d\n",EmptyQueueLink(sqLink));
 //入队操作
 for (i=0;i<=20;i++)
 {
  EnQueueLink(&sqLink,i+1);
 }
 //判断队列是否为空
 printf("is Empty?%d,len=%d\n",EmptyQueueLink(sqLink),LengthQueueLink(sqLink));
 //打印队列
 printSqQueueLink(sqLink);
 //出队列操作
 DeQueueLink(sqLink,&data);
 //判断队列是否为空
 printf("is Empty?%d,len=%d\n",EmptyQueueLink(sqLink),LengthQueueLink(sqLink));
 //打印队列
 printSqQueueLink(sqLink);
 //获取队头元素的值
 GetHeadLink(sqLink,&data);
 printf("the first node value is %d\n",data);
 return 0;
}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • C++实例输入多行数字到数组

    C++实例输入多行数字到数组

    这篇文章主要介绍了C++实例输入多行数字到数组的相关资料,这里提供实例代码帮助大家学习理解,需要的朋友可以参考下
    2016-12-12
  • OpenCV实现特征检测和特征匹配方法汇总

    OpenCV实现特征检测和特征匹配方法汇总

    一幅图像中总存在着其独特的像素点,这些点我们可以认为就是这幅图像的特征,成为特征点,本文主要介绍了OpenCV实现特征检测和特征匹配方法,感兴趣的可以了解一下
    2021-08-08
  • 使用C++一步步实现俄罗斯方块

    使用C++一步步实现俄罗斯方块

    本文给大家分享的是作者在使用C++制作俄罗斯方块的时候的思路分析以及开发准备和实验原理,都是些基础的知识储备,希望大家能够喜欢,具体的代码我们下一节再分享给大家
    2017-12-12
  • 关于C++中0是十进制还是八进制的问题

    关于C++中0是十进制还是八进制的问题

    本篇文章中,小编将为大家介绍关于C++中0是十进制还是八进制的问题,有需要的朋友可以参考一下
    2013-04-04
  • C语言超详细讲解指针的概念与使用

    C语言超详细讲解指针的概念与使用

    本文主要讲解C语言中指针和字符串的关系以及指针和数组的关系,在看本文之前大家可以先看看博主之前的C语言基础篇,先对C语言指针先有个基础的了解,有助于对本文章有更深一步的了解
    2022-05-05
  • C语言、C++内存对齐问题详解

    C语言、C++内存对齐问题详解

    这篇文章主要介绍了C语言、C++内存对齐问题详解,内存对齐的问题主要存在于理解struct和union等复合结构在内存中的分布,需要的朋友可以参考下
    2014-10-10
  • C++学习笔记之浅谈异常处理

    C++学习笔记之浅谈异常处理

    C++ 提供了异常机制,让我们能够捕获运行时错误,本文就详细的介绍了C++异常处理入门,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-10-10
  • 详解C++ string常用截取字符串方法

    详解C++ string常用截取字符串方法

    这篇文章主要介绍了C++ string常用截取字符串方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-05-05
  • Cocos2d-x触摸事件实例

    Cocos2d-x触摸事件实例

    这篇文章主要介绍了Cocos2d-x触摸事件实例,本文代码中包含大量注释来说明Cocos2d-x中的触摸事件使用示例,需要的朋友可以参考下
    2014-09-09
  • C语言实现数独游戏的求解

    C语言实现数独游戏的求解

    这篇文章主要为大家详细介绍了C语言实现数独游戏的求解,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-01-01

最新评论