基本概念


 

  队列是只允许在一端进行插入操作,另一端进行删除操作的线性表。

   我们规定,允许删除的叫做队首“head”,允许插入的叫做队尾“tail”。

  

基本操作


  我们规定,一个结点包含数值域与指针域两部分,数值域存放链表所需要用到的非指针型数值,指针域用于存放数值以及指向下一个结点的next指针。

  

  /*定义链表队列*/

  struct Node{ int dota;struct Node *next}node;   //结构体存放结点

  struct linkqueue{struct Node *head;struct Node *tail}queue;  //存放队头指针和队尾指针,不存放在Node中是为了节省节点入队时占用的内存空间

  

   /* 初始化队列 */

  1.队头指针和队尾指针共同申请一个内存空间,我们假定申请到的内存地址是0X01

  2.结点下一结指向NULL

     注意:头结点的数据域为空

  PS:框框下头的&q、head、tail表示的是已串到0X01内存地址上的结点

  

   /* 入队操作 */

    1.申请新结点p,申请内存空间,我们规定申请到的内存空间地址为0X02

  2.输入的数据elem存放在新结点数据中

  3.新结点p的下一结指向NULL

  4.尾结点tail的下一结点指向新结点p,即把新结点p串到链表中

  5.队尾指针tail->next指向新结点,保证尾结点指针tail->next始终指向NULL

  

  

  

  /* 出队操作 */

  1.申请结点指针p,指向队头结点head,内存地址为0X01

  2.队头结点head传入下一结点,以免其被free();而失去了删除的这一端

  3.free();指针p指向的结点,原队头结点head所在的内存地址0X01

  4.p=NULL //避免野指针

  

  

  /* 打印操作 */

  1.若队头结点还位于内存地址0X01上,由于0X01内存地址上结点的数值域未写入,所以队头结点head应移入下一结点中,即head=head->next;

  2.申请一个结点p

  3.把结点p串入含有数值域的结点,即p=q->head->next,q是结构体queue类型的队列。

  4.遍历打印p=p->next,直到NULL。

  

源代码


  

/**********************************************************************
实现一个queue
输入: 7 6 8 6 6 7 0 4 1(队列) 9(出队的个数)
输出:The queue is empty!
**********************************************************************/
#include<stdio.h>
#include<stdlib.h> typedef struct Node
{
int data;
struct node *next;
}node;
/* 当链式队列的头尾节点指针定义成为一个单独的结构体,避免在新增节点时占用过多的空间 */
typedef struct list
{
struct Node *head;
struct Node *tail;
}queue; void queue_init(queue *q);
void queue_in(queue *q,int elem);
void queue_out(queue *q);
void queue_print(queue *q);
void queue_empty(queue *q); int main()
{
queue q;
queue_init(&q);
int elem;
printf("input:");
while(scanf("%d",&elem)!=EOF)
{
getchar();
queue_in(&q,elem);
}
queue_print(&q);
queue_out(&q);
queue_print(&q);
queue_empty(&q);
return 0;
} void queue_init(queue *q)
{
q->head=q->tail=(node*)malloc(sizeof(node)); //head,tail共同指向一个内存空间
q->tail->next=NULL; //队尾指针的next指针指向NULL,头结点head不变
return;
} void queue_in(queue *q,int elem)
{
node *p;
p=(node *)malloc(sizeof(node));
p->data=elem;
p->next=NULL;
q->tail->next=p;
q->tail=p;
return;
} void queue_out(queue *q)
{
node *p;
int i; //i==出队的数据个数
printf("The number of out queue:\n");
scanf("%d",&i);
while(i)
{
p=q->head;
q->head=q->head->next;
free(p);
p=NULL; //防止野指针
i--;
}
return;
} void queue_print(queue *q)
{ node *p;
p=q->head->next;
while(p!=NULL)
{
printf("%d",p->data);
p=p->next;
}
return;
} void queue_empty(queue *q)
{
if(q->head->next==NULL)
{
printf("The queue is empty!\n");
}
return;
}

队列queue(2):链表实现队列的更多相关文章

  1. C++栈(stack)、队列(queue)、链表(list)的常用函数

    C++队列Queue是一种容器适配器,它给予程序员一种先进先出(FIFO)的数据结构.1.back() 返回一个引用,指向最后一个元素2.empty() 如果队列空则返回真3.front() 返回第一 ...

  2. [数据结构]——链表(list)、队列(queue)和栈(stack)

    在前面几篇博文中曾经提到链表(list).队列(queue)和(stack),为了更加系统化,这里统一介绍着三种数据结构及相应实现. 1)链表 首先回想一下基本的数据类型,当需要存储多个相同类型的数据 ...

  3. Java多线程总结之线程安全队列Queue

    在Java多线程应用中,队列的使用率很高,多数生产消费模型的首选数据结构就是队列.Java提供的线程安全的Queue可以分为阻塞队列和非阻塞队列,其中阻塞队列的典型例子是BlockingQueue,非 ...

  4. Java数据结构——用双端链表实现队列

    //================================================= // File Name : LinkQueue_demo //---------------- ...

  5. 队列(Queue)--环形队列、优先队列和双向队列

    1. 队列概述 队列和堆栈都是有序列表,属于抽象型数据类型(ADT),所有加入和删除的动作都发生在不同的两端,并符合First In, First Out(先进先出)的特性. 特性: ·FIFO ·拥 ...

  6. STL中的单向队列queue

    转载自:http://blog.csdn.net/morewindows/article/details/6950917 stl中的queue指单向队列,使用时,包含头文件<queue>. ...

  7. 什么是队列(Queue)?

    类似于链表和堆栈,队列也是存储数据的结构.队列中数据进入队列的顺序很重要,一般来说,队列就是一群人或者事物按照排好的顺序等待接受服务或者处理. 定义:队列,又称为伫列(queue),是先进先出(FIF ...

  8. 【Java数据结构学习笔记之二】Java数据结构与算法之队列(Queue)实现

      本篇是数据结构与算法的第三篇,本篇我们将来了解一下知识点: 队列的抽象数据类型 顺序队列的设计与实现 链式队列的设计与实现 队列应用的简单举例 优先队列的设置与实现双链表实现 队列的抽象数据类型 ...

  9. java队列——queue详细分析

    Queue: 基本上,一个队列就是一个先入先出(FIFO)的数据结构 Queue接口与List.Set同一级别,都是继承了Collection接口.LinkedList实现了Deque接 口.   Q ...

  10. java中队列Queue的使用

    1.在java5中新增加了java.util.Queue接口,用以支持队列的常见操作.Queue接口与List.Set同一级别,都是继承了Collection接口.Queue使用时要尽量避免Colle ...

随机推荐

  1. Winwos Server 2012发布ASP.NET MVC5 项目

    一.本文实验环境: Windows Server 2012 R2 Visual Studio 2015 项目为:ASP.NET MVC 5.0,使用的是SQL SERVER 2008 R2数据库 二. ...

  2. input常见类型

       值   描述  text   默认.定义单行输入字段,用户可在其中输入文本.默认是 20 个字符  button   定义可点击的按钮(大多与 JavaScript 使用来启动脚本)  chec ...

  3. AIO5物料清单(BOM)列表,搜索编码和名称无效

    问题: AIO5物料清单(BOM)列表,搜索编码和名称无效.如图: 原因分析 AIO5的BOM是在二次开发平台上做的,在制作自定义单据的时候[查询参数设置]没有设置.如下图: 解决方案 工具:AIO5 ...

  4. VMware下设置Centos7联网与固定IP连接Xshell

    爱折腾的小伙伴应该经常会用Vmware安装一些虚拟机用于学习,但是比如装了Linux,经常操作的时候非常切换窗口的时候非常麻烦,所以很多人都会选择用Xshell来连接本地的Linux虚拟机,但是用Xs ...

  5. 在azure中建立DDC集群

    在Azure上建立DDC集群 建立3台虚拟机作为UCP集群,3台虚拟机作为DTR集群. 资源组:HYD-DockerDateCenter 虚拟机size:DS3 4核14G 系统:ubuntu14.0 ...

  6. Spring-MVC理解之一:应用上下文webApplicationContext

    一.先说ServletContext javaee标准规定了,servlet容器需要在应用项目启动时,给应用项目初始化一个ServletContext作为公共环境容器存放公共信息.ServletCon ...

  7. 初窥c++11:lambda函数及其用法

    转载于:点击打开链接 为什么需要lambda函数 匿名函数是许多编程语言都支持的概念,有函数体,没有函数名.1958年,lisp首先采用匿名函数,匿名函数最常用的是作为回调函数的值.正因为有这样的需求 ...

  8. [P4基础]p4app的Docker镜像仓使用详解

    How to use the p4lang/p4app Docker image 本文参考 孙勇峰博客 和 p4app README 以及 p4app Dockerfile 结合自己的理解做一些记录, ...

  9. 【福利】十一起,小冰科技所有UWP产品免费半个月

    从十月一日起(UTC协调世界时),至十月十五,小冰科技所有UWP产品免费半个月!!!!!! 注意是UTC哦,中国区,比UTC早8个小时,要等到十月一号早晨八点开始... 现在小冰科技旗下一共发布了 5 ...

  10. Exif Info 隐私政策

    隐私政策 本应用尊重并保护所有使用服务用户的个人隐私权.为了给您提供更准确.更有个性化的服务,本应用会按照本隐私权政策的规定使用和披露您的个人信息.但本应用将以高度的勤勉.审慎义务对待这些信息.除本隐 ...