队列也是一种特殊的线性表,它的特点是先入先出(FIFO,即first in first out)。它的意思也很直观,想象一下排队买票,先排的人先买(插队是不对的,所以别去想)。它也是很常用的数据结构,比如说医院的排队等候系统用这个数据结构就很合适。那么这个数据结构该怎么写呢?

下面为队列的抽象数据结构:

typedef struct NODE {
  datatype data;
  struct NODE *next;
} node; //一般的线性表
typedef struct Queue {
  int len;           //队列长度
  node *head, *tail; //队列的头和尾
} queue;

因为这个结构需要在队尾插入元素,删除队首的元素,所以需要两个指针分别指向头和尾。

下面为队列的插入函数:

void push(queue *q, datatype e) {
  node *p = (node *)malloc(sizeof(node));
  p->data = e;
  p->next = NULL;
  if (q->head == NULL)
    q->head = p;
  if (q->tail == NULL)
    q->tail = p;
  else {
    q->tail->next = p;
    q->tail = p;
  }
  q->len++;
}

如果是空队列,就让首尾都指向刚创建的节点。否者让队尾指向新节点。

下面为删除函数:

void pop(queue *q) {
  if (isempty(q)) {
    printf("这个队列是空的。\n");
    return;
  } else {
    datatype tmp = q->head->data;
    node *p = (node *)malloc(sizeof(node));
    p = q->head;
    q->head = q->head->next;
    if (q->head == NULL)
      q->tail = NULL;
    free(p);
    q->len--;
    printf("%d\n", tmp);
  }
}

也需要判断是否为空,不为空还要判断删除后是否为空,不然队尾会变得很奇怪。

总的代码如下:

#include <stdio.h>
#include <stdlib.h>
#define datatype int
#define bool int
#define true 1
#define false 0
typedef struct NODE {
  datatype data;
  struct NODE *next;
} node; //一般的线性表
typedef struct Queue {
  int len;           //队列长度
  node *head, *tail; //队列的头和尾
} queue;
queue *initque();               //创建队列
void push(queue *, datatype); //向队尾插入数据e
void pop(queue *);              //删除队首元素并输出
bool isempty(queue *);          //判断队列是否为空
int main(void) {
  int choice;
  queue *que = (queue *)malloc(sizeof(queue));
  que = initque();
  printf("1、加入元素\n2、删除并输出元素\nq、退出\n请选择:");
  ) {
    ) {
      int tmp;
      printf("请输入要添加的元素:");
      scanf("%d", &tmp);
      push(que, tmp);
    } )
      pop(que);
    printf("1、加入元素\n2、删除并输出元素\nq、退出\n请选择:");
  }
  ;
}
queue *initque() {
  queue *q = (queue *)malloc(sizeof(queue));
  q->head = NULL;
  q->tail = NULL;
  q->len = ;
  return q;
}
void push(queue *q, datatype e) {
  node *p = (node *)malloc(sizeof(node));
  p->data = e;
  p->next = NULL;
  if (q->head == NULL)
    q->head = p;
  if (q->tail == NULL)
    q->tail = p;
  else {
    q->tail->next = p;
    q->tail = p;
  }
  q->len++;
}
void pop(queue *q) {
  if (isempty(q)) {
    printf("这个队列是空的。\n");
    return;
  } else {
    datatype tmp = q->head->data;
    node *p = (node *)malloc(sizeof(node));
    p = q->head;
    q->head = q->head->next;
    if (q->head == NULL)
      q->tail = NULL;
    free(p);
    q->len--;
    printf("%d\n", tmp);
  }
}
bool isempty(queue *q) {
  )
    return true;
  else
    return false;
}

数据结构——线性表——队列(queue)的更多相关文章

  1. [从今天开始修炼数据结构]线性表及其实现以及实现有Itertor的ArrayList和LinkedList

    一.线性表 1,什么是线性表 线性表就是零个或多个数据元素的有限序列.线性表中的每个元素只能有零个或一个前驱元素,零个或一个后继元素.在较复杂的线性表中,一个数据元素可以由若干个数据项组成.比如牵手排 ...

  2. [数据结构-线性表1.2] 链表与 LinkedList<T>(.NET 源码学习)

    [数据结构-线性表1.2] 链表与 LinkedList<T> [注:本篇文章源码内容较少,分析度较浅,请酌情选择阅读] 关键词:链表(数据结构)    C#中的链表(源码)    可空类 ...

  3. [置顶] ※数据结构※→☆线性表结构(queue)☆============循环队列 顺序存储结构(queue circular sequence)(十)

    循环队列 为充分利用向量空间,克服"假溢出"现象的方法是:将向量空间想象为一个首尾相接的圆环,并称这种向量为循环向量.存储在其中的队列称为循环队列(Circular Queue). ...

  4. [置顶] ※数据结构※→☆线性表结构(queue)☆============队列 顺序存储结构(queue sequence)(八)

    队列是一种特殊的线性表,特殊之处在于它只允许在表的前端(front)进行删除操作,而在表的后端(rear)进行插入操作,和栈一样,队列是一种操作受限制的线性表.进行插入操作的端称为队尾,进行删除操作的 ...

  5. [置顶] ※数据结构※→☆线性表结构(queue)☆============优先队列 链式存储结构(queue priority list)(十二)

    优先队列(priority queue) 普通的队列是一种先进先出的数据结构,元素在队列尾追加,而从队列头删除.在优先队列中,元素被赋予优先级.当访问元素时,具有最高优先级的元素最先删除.优先队列具有 ...

  6. Java学习笔记(2)----散列集/线性表/队列/集合/图(Set,List,Queue,Collection,Map)

    1. Java集合框架中的所有实例类都实现了Cloneable和Seriablizable接口.所以,它们的实例都是可复制和可序列化的. 2. 规则集存储的是不重复的元素.若要在集合中存储重复的元素, ...

  7. C#实现数据结构——线性表(上)

    什么是线性表 数据结构中最常用也最简单的应该就是线性表,它是一种线性结构(废话,不是线性结构怎么会叫线性表?当然不是废话,古人公孙龙就说白马非马,现代生物学家也说鲸鱼不是鱼). 那什么是线性结构? 按 ...

  8. k:特殊的线性表—队列

    队列的概念:  队列是另一种特殊的线性表,它的特殊性体现在其只允许在线性表的一端插入数据元素,在线性表的另一端删除数据元素(一般会采用在线性表的表尾那端(没被head指针所指的那端)插入数据元素,在线 ...

  9. 常用数据结构-线性表及Java 动态数组 深究

    [Java心得总结六]Java容器中——Collection在前面自己总结的一篇博文中对Collection的框架结构做了整理,这里深究一下Java中list的实现方式 1.动态数组 In compu ...

随机推荐

  1. 【深入理解JVM】类加载器与双亲委派模型

    原文链接:http://blog.csdn.net/u011080472/article/details/51332866,http://www.cnblogs.com/lanxuezaipiao/p ...

  2. requests库使用

    介绍: 发送HTTP请求的第三方库,比起之前用到的urllib,requests模块的api更加便捷(本质就是封装了urllib3) 安装:pip3 install requests 学习reques ...

  3. JavaScript保留关键字2。

    一些不做解释的关键字是在js中预留的东西. abstract 抽象  . arguments  参数 标识符arguments是指向实参对象的引用,实参对象是一个类数组对象. boolean 布尔值. ...

  4. 关于vue学习中的一些

    1.Jinkey大神的新手入门攻略 2.小凡vuejs2的视频地址 3.网友翻译的vuejs2官方中文文档 部分报错处理: 1.错误一 vue.js?b6db:2611[Vue warn]: Unkn ...

  5. 【Luogu3807】【模板】卢卡斯定理(数论)

    题目描述 给定\(n,m,p(1≤n,m,p≤10^5)\) 求 \(C_{n+m}^m mod p\) 保证\(P\)为\(prime\) \(C\)表示组合数. 一个测试点内包含多组数据. 输入输 ...

  6. 锐动视频SDK在金融业务加密双录管理系统通用解决方案

    为了更好地保障消费者的合法权益,银监会和保监会提出了要求,在银行.保险从业人员销售理财产品或代理其他机构销售产品时,同期进行录音录像,确保销售人员按程序.按规定介绍产品,以便购买者更清楚地了解产品的性 ...

  7. 关于jstl的使用

    1.jsp中el表达式无法被解析 使用jstl标签的时候,发现el表达式无法被解析,后来查阅资料发现jsp中需要添加<%@page isELIgnored="false" % ...

  8. c#多线程同步之Semaphore

    一提到Semaphore(信号量)的使用,还挺有意思的,它允许多个线程同时访问多个稀有资源,我立马想到银行的ATM机取钱的场景.看下面的代码: ); public static void StartT ...

  9. java容器类2:Map及HashMap深入解读

    Java的编程过程中经常会和Map打交道,现在我们来一起了解一下Map的底层实现,其中的思想结构对我们平时接口设计和编程也有一定借鉴作用.(以下接口分析都是以jdk1.8源码为参考依据) 1. Map ...

  10. tensorflow 学习日志

    Windows安装anaconda 和 TensorFlow anaconda : https://zhuanlan.zhihu.com/p/25198543        anaconda 使用与说 ...