全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

C语言数据结构链表队列的实现

C语言数据结构链表队列的实现

1.写在前面

  队列是一种和栈相反的,遵循先进先出原则的线性表。

  本代码是严蔚敏教授的数据结构书上面的伪代码的C语言实现代码。

  分解代码没有包含在内的代码如下:

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

#define OK 1
#define ERROR 0

typedef int QElemtype;
typedef int status;

2.代码分解

2.1对队列和节点的结构定义

typedef struct QNode //对节点的结构定义
{
  QElemtype data;
  struct QNode *next;
}QNode,*QueuePtr;

typedef struct{   //对队列的结构定义
  QueuePtr head;
  QueuePtr rear;
}LinkQueue;

  |说明:

    1.队列的节点首先要保存元素,其次要指引下一个元素的位置,这是实现线性存储的基础也是关键。

    2.队列中定义了两个节点指针,第一个 head 用来表示 队头,允许移除元素。与之相反的是 rear  用来表示 队尾,允许插入元素。

    3.为什么这么定义?

2.2 初始化和回收队列

status initQueue(LinkQueue* que) //初始化队列
{
  que->head=que->rear=(QueuePtr)malloc(sizeof(QNode));
  if(!que->head) //这段代码对队列里面的用户自定义数据类型进行了初始化
    return ERROR;
  return OK;
}
status destoryQueue(LinkQueue* que) //回收队列
{
  while(que->head)
  {
    que->rear = que->head->next;
    free(que->head);
    que->head=que->rear;
  }
  return OK;
}

  |说明:

    1.初始化很简单,就是为队列内的两个重要节点分配空间。

    2.队列的回收,思路很巧妙

 循环条件是  队列的队头节点 head 存在
    {
      此处rear起到临时变量的作用,不断指向head->next的同时,释放head。这样处理可以干净的把包含头节点在内的队列清理干净。
 
     }

2.3 添加和删除元素

status enQueue(LinkQueue* que,QElemtype e)
{
  QueuePtr p = (QueuePtr)malloc(sizeof(QNode));
  if(!p) //若未能申请到空间,便退出
    return ERROR;
  p->data=e;
  p->next=NULL;

  que->rear->next = p;
  que->rear=p;
  return OK;
}

status delQueue(LinkQueue* que,QElemtype *t)
{
  if(que->rear==que->head)
    return ERROR; //队列为空

  QueuePtr p = que->head->next;
  *t=p->data;

  que->head->next=p->next;
  if(que->rear==p) //这个判断是 确保在清空队列的时候,让rear指针归位。
    que->rear=que->head;
  free(p);
  return OK;
}

  |说明:

    1.添加元素的思路:新建一个节点,并给其赋值(data,next)。让队列的尾部相接此节点,同时更新尾部节点。

    2.删除元素的思路:首先判断节点是否为空?然后用临时节点从队头获取到第一个节点,即head->next,(我们的head节点并不保存元素),获取其地址后,更新队头节点所指的第一个节点获取值后释放该地址空间。

2.4 遍历队列和测试方法

status viewQueue(LinkQueue* que)
{
  if(que->rear == que->head)
    return ERROR;
  
  QueuePtr p =que->head->next;
  while(p)
  {
    printf("val:%d",p->data);
    p=p->next;
  }
  return OK;
}

int main(int argc, char **argv)
{
  LinkQueue myQueue;
  initQueue(&myQueue);
  for(int i=1;i<=5;i++)
    enQueue(&myQueue,i);
  viewQueue(&myQueue);
  
  QElemtype a;
  for(int i=0;i<5;i++)
  {
    delQueue(&myQueue,&a);
    printf("%d\n",a);
  }
  destoryQueue(&myQueue);
  printf("fuck !");  
  return 0;
}


# C语言数据结构链表队列的实现  # 数据结构  # 队列  # C语言 队列的实现全解析  # C语言数据结构进阶之栈和队列的实现  # C语言超详细讲解队列的实现及代码  # 第一个  # 为空  # 的是  # 这是  # 是一种  # 遍历  # 这段  # 很简单  # 自定义  # 与之  # 到第  # 书上  # 进行了  # 移除  # 清空  # 新建一个  # 给其  # 链表  # 写在前面 


相关文章: c++23 std::expected怎么用 c++优雅处理函数错误返回【详解】  详解一款开源免费的.NET文档操作组件DocX(.NET组件介绍之一)  网站设计制作公司地址,网站建设比较好的公司都有哪些?  国美网站制作流程,国美电器蒸汽鍋怎么用官方网站?  东莞专业网站制作公司有哪些,东莞招聘网站哪个好?  外贸公司网站制作哪家好,maersk船公司官网?  建站之星代理费用多少?最新价格详情介绍  常州自助建站费用包含哪些项目?  如何高效完成自助建站业务培训?  百度网页制作网站有哪些,谁能告诉我百度网站是怎么联系?  定制建站流程步骤详解:一站式方案设计与开发指南  如何通过智能用户系统一键生成高效建站方案?  如何制作网站标识牌,动态网站如何制作(教程)?  建站之星五站合一营销型网站搭建攻略,流量入口全覆盖优化指南  免费公司网站制作软件,如何申请免费主页空间做自己的网站?  公司网站制作费用多少,为公司建立一个网站需要哪些费用?  简单实现Android验证码  ,想在网上投简历,哪几个网站比较好?  如何通过NAT技术实现内网高效建站?  建站之星后台密码遗忘或太弱?如何重置与强化?  b2c电商网站制作流程,b2c水平综合的电商平台?  如何通过二级域名建站提升品牌影响力?  高防网站服务器:DDoS防御与BGP线路的AI智能防护方案  如何快速查询域名建站关键信息?  IOS倒计时设置UIButton标题title的抖动问题  如何在香港免费服务器上快速搭建网站?  如何快速搭建响应式可视化网站?  如何快速搭建虚拟主机网站?新手必看指南  如何用狗爹虚拟主机快速搭建网站?  如何在万网开始建站?分步指南解析  大连企业网站制作公司,大连2025企业社保缴费网上缴费流程?  如何在IIS管理器中快速创建并配置网站?  专业制作网站的公司哪家好,建立一个公司网站的费用.有哪些部分,分别要多少钱?  香港代理服务器配置指南:高匿IP选择、跨境加速与SEO优化技巧  简易网站制作视频教程,使用记事本编写一个简单的网页html文件?  如何通过虚拟主机空间快速建站?  Swift中循环语句中的转移语句 break 和 continue  外汇网站制作流程,如何在工商银行网站上做外汇买卖?  定制建站模板如何实现SEO优化与智能系统配置?18字教程  香港服务器租用费用高吗?如何避免常见误区?  开封网站制作公司,网络用语开封是什么意思?  建站之星导航菜单设置与功能模块配置全攻略  php条件判断怎么写_ifelse和switchcase的使用区别【对比】  南京网站制作费用,南京远驱官方网站?  网站广告牌制作方法,街上的广告牌,横幅,用PS还是其他软件做的?  如何选择服务器才能高效搭建专属网站?  湖北网站制作公司有哪些,湖北清能集团官网?  黑客入侵网站服务器的常见手法有哪些?  如何在腾讯云免费申请建站?  建站主机与服务器功能差异如何区分? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。