队列简单操作
2015-12-30 22:00
309 查看
队列
是一种特殊的线性表,特殊之处在于它只允许在表的前端(front)进行删除操作,而在表的后端(rear)进行插入操作,和栈一样,队列是一种操作受限制的线性表。进行插入操作的端称为队尾,进行删除操作的端称为队头。队列中没有元素时,称为空队列。队列的数据元素又称为队列元素。在队列中插入一个队列元素称为入队,从队列中删除一个队列元素成为出队。因为队列只允许在一段插入,在另一端删除,所以只有最早进入队列的元素才能最先从队列中删除,故队列又称为先进先出(FIFO—first in first out)线性表。[1]
顺序队列
建立顺序队列结构必须为其静态分配或动态申请一片连续的存储空间,并设置两个指针进行管理。一个是队头指针front,它指向队头元素;另一个是队尾指针rear,它指向下一个入队元素的存储位置。
每次在队尾插入一个元素是,rear增1;每次哎队头删除一个元素时,front增1。随着插入和删除操作的进行,队列元素的个数不断变化,队列所占的存储空间也在为队列结构所分配的连续空间中移动。当front=rear时,队列中没有任何元素,称为空队列。当rear增加到指向分配的连续空间之外时,队列无法再插入新元素,但这时往往还有大量可用空间未被占用,这些空间是已经出队的队列元素曾经占用过得存储单元。
顺序队列中的溢出现象:
(1) “下溢”现象:当队列为空时,做出队运算产生的溢出现象。“下溢”是正常现象,常用作程序控制转移的条件。(2)”真上溢”现象:当队列满时,做进栈运算产生空间溢出的现象。“真上溢”是一种出错状态,应设法避免。
(3)”假上溢”现象:由于入队和出队操作中,头尾指针只增加不减小,致使被删元素的空间永远无法重新利用。当队列中实际的元素个数远远小于向量空间的规模时,也可能由于尾指针已超越向量空间的上界而不能做入队操作。该现象称为”假上溢”现象。
循环队列
在实际使用队列时,为了使队列空间能重复使用,往往对队列的使用方法稍加改进:无论插入或删除,一旦rear指针增1或front指针增1 时超出了所分配的队列空间,就让它指向这片连续空间的起始位置。自己真从MaxSize-1增1变到0,可用取余运算rear%MaxSize和front%MaxSize来实现。这实际上是把队列空间想象成一个环形空间,环形空间中的存储单元循环使用,用这种方法管理的队列也就称为循环队列。处了一些简单应用之外,真正实用的队列时循环队列。[2]在循环队列中,当队列为空时,有front=rear,而当所有队列空间全占满时,也有front=rear。为了区别这两种情况,规定循环队列最多只能有MaxSize-1个队列元素,当循环队列中只剩下一个空存储单元时,队列就已经满了。因此,队列判空的条件时front=rear,而队列判满的条件时front=(rear+1)%MaxSize。
#include <stdio.h> #include <stdlib.h> typedef struct linklist { int data; struct linklist *next; } node; typedef struct linkQueue { struct linklist *head; struct linklist *tail; } linkqueue; linkqueue* createlinkequeue() { linkqueue *newqueue = (linkqueue*)malloc(sizeof(linkqueue)); newqueue->head = NULL; newqueue->tail = NULL; return newqueue; } linkqueue* insertnode(linkqueue *nowqueue, int i) { node *newnode; newnode = (node*)malloc(sizeof(node)); newnode->data = i; newnode->next = NULL; if (!nowqueue->tail) { nowqueue->head = newnode; nowqueue->tail = newnode; } else { nowqueue->tail->next = newnode; nowqueue->tail = newnode; } return nowqueue; } linkqueue* deletenode(linkqueue *nowqueue) { node *dnode; if (nowqueue->head == NULL) { printf("the queue is empty now\n"); return nowqueue; } dnode = nowqueue->head; if (nowqueue->head == nowqueue->tail) { nowqueue->head = NULL; nowqueue->tail = NULL; free(dnode); } else { nowqueue->head = nowqueue->head->next; free(dnode); } return nowqueue; } void printlinkqueue(linkqueue *queue) { node *qnode; qnode = queue->head; while (qnode) { printf("%d\n", qnode->data); qnode = qnode->next; } } int main() { int m; printf("the total number in the queue:\n"); scanf("%d", &m); linkqueue *queue; queue = createlinkequeue(); printf("enter the num\n"); for (int i = 1; i <= m; i++) { int n; scanf("%d", &n); queue = insertnode(queue, n); } printf("the number you wanna delete\n"); int h; scanf("%d", &h); for (int i = 1; i <= h; i++) { queue = deletenode(queue); } printlinkqueue(queue); return 0; }
相关文章推荐
- POJ 2115 C Looooops(扩展欧几里得应用)
- freemarker中参数及java片段的使用方法
- 155,纯代码创建标签和按钮,并关联点击事件
- Java读写Excel文件示例
- 如何知道浏览器所支持的属性和方法呢?
- 【数据结构】顺序栈的基本操作
- UVa 10976 Fractions Again?!(分数拆分)
- uva507
- java socket传送和接受byte[]
- 计算沙盒下文件夹内容大小 清空沙盒 文件 目录
- "><img src=x onerror=alert(1)>
- 【数据传输 2】批量导入的前奏:将Excel表中的数据转换为DataTable类型
- 【数据传输 2】批量导入的前奏:将Excel表中的数据转换为DataTable类型
- HBase 常见错误-ERROR: Can't get master address from ZooKeeper; znode data == null解决办法
- 一晚上将一个模板整合进了DJANGO
- Linux文件和目录管理常用命令(上)
- UVa 11509 Maximum Product(最大乘积)
- cocos2d-x 3.0游戏实例学习笔记《卡牌塔防》第八部---怪物出场
- 玩转递归
- 超强、超详细Redis数据库入门教程