数据结构——线性表——队列(queue)
队列也是一种特殊的线性表,它的特点是先入先出(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)的更多相关文章
- [从今天开始修炼数据结构]线性表及其实现以及实现有Itertor的ArrayList和LinkedList
一.线性表 1,什么是线性表 线性表就是零个或多个数据元素的有限序列.线性表中的每个元素只能有零个或一个前驱元素,零个或一个后继元素.在较复杂的线性表中,一个数据元素可以由若干个数据项组成.比如牵手排 ...
- [数据结构-线性表1.2] 链表与 LinkedList<T>(.NET 源码学习)
[数据结构-线性表1.2] 链表与 LinkedList<T> [注:本篇文章源码内容较少,分析度较浅,请酌情选择阅读] 关键词:链表(数据结构) C#中的链表(源码) 可空类 ...
- [置顶] ※数据结构※→☆线性表结构(queue)☆============循环队列 顺序存储结构(queue circular sequence)(十)
循环队列 为充分利用向量空间,克服"假溢出"现象的方法是:将向量空间想象为一个首尾相接的圆环,并称这种向量为循环向量.存储在其中的队列称为循环队列(Circular Queue). ...
- [置顶] ※数据结构※→☆线性表结构(queue)☆============队列 顺序存储结构(queue sequence)(八)
队列是一种特殊的线性表,特殊之处在于它只允许在表的前端(front)进行删除操作,而在表的后端(rear)进行插入操作,和栈一样,队列是一种操作受限制的线性表.进行插入操作的端称为队尾,进行删除操作的 ...
- [置顶] ※数据结构※→☆线性表结构(queue)☆============优先队列 链式存储结构(queue priority list)(十二)
优先队列(priority queue) 普通的队列是一种先进先出的数据结构,元素在队列尾追加,而从队列头删除.在优先队列中,元素被赋予优先级.当访问元素时,具有最高优先级的元素最先删除.优先队列具有 ...
- Java学习笔记(2)----散列集/线性表/队列/集合/图(Set,List,Queue,Collection,Map)
1. Java集合框架中的所有实例类都实现了Cloneable和Seriablizable接口.所以,它们的实例都是可复制和可序列化的. 2. 规则集存储的是不重复的元素.若要在集合中存储重复的元素, ...
- C#实现数据结构——线性表(上)
什么是线性表 数据结构中最常用也最简单的应该就是线性表,它是一种线性结构(废话,不是线性结构怎么会叫线性表?当然不是废话,古人公孙龙就说白马非马,现代生物学家也说鲸鱼不是鱼). 那什么是线性结构? 按 ...
- k:特殊的线性表—队列
队列的概念: 队列是另一种特殊的线性表,它的特殊性体现在其只允许在线性表的一端插入数据元素,在线性表的另一端删除数据元素(一般会采用在线性表的表尾那端(没被head指针所指的那端)插入数据元素,在线 ...
- 常用数据结构-线性表及Java 动态数组 深究
[Java心得总结六]Java容器中——Collection在前面自己总结的一篇博文中对Collection的框架结构做了整理,这里深究一下Java中list的实现方式 1.动态数组 In compu ...
随机推荐
- VBA Excel WideCharToMultiByte Compile error on 64-bit System
Compile Error: The code in this project must be updated for use on64-bit systems. Please review and ...
- RobotFramework下的http接口自动化Get Response Body关键字的使用
Get Response Body 关键字在上面已经有用到了,服务器端在处理完成了发出的http请求后,会给出对应的响应结果,那么Get Response Body这个关键字就是来获取响应结果中的主体 ...
- [USACO07NOV]Cow Relays
map+floyed+矩阵乘法(倍增floyed) # include <stdio.h> # include <stdlib.h> # include <iostrea ...
- 关于input 的选中,自定义input[type="checkbox"]样式
1.css 呈现 选中后 的input的样式可以用 /*背景图*/ background:url('../pc/images/archives/icon_choosed.png') no ...
- WPF-悬浮窗(类似于360)
boss要求开发一个类似于360的悬浮窗,如下图所示: 目前采用的是wpf做的客户端,之前有个winform的项目,我参考了下,完成了wpf版的悬浮窗. Height=" WindowSta ...
- Linux文件目录权限对比
读取权限(r) 文件只有r权限: 具有读取\阅读文件内容权限1.只能使用查看类命令 cat.head.tail.less.more2.不能复制,也就是不能使用cp命令3.不能移动,不能使用mv命令移动 ...
- 产生AJAX跨域问题的原因
1.浏览器限制 浏览器出于安全的角度,当产生跨域,则浏览器会对请求进行一些校验,校验不通过,则报跨域安全问题 2.跨域指发出去的请求不是本域的,协议.域名.端口任何一项不一样就认为是跨域 3.XHR( ...
- 使用Dreamweaver正则表达式替换href中的内容
在Dreamweaver中使用正则表达式替换href中的内容,就像下面这些href中的内容复杂多样的情况下,href="/html/u.html",href="/tuho ...
- u-boot的SPL源码流程分析
上次梳理了一下SPL的基本概念和代码总体思路,这次就针对代码跑的流程做个梳理.SPL中,入口在u-boot-spl.lds中 ENTRY(_start) SECTIONS { .text : { __ ...
- Servlet的三个域对象
我们在开发javaweb项目的时候,经常会遇到jsp和Servet之间互相传值,既然有传值,就要有对象来传,这里先说Servlet的三大域对象,request,session,application他 ...