队列是限定在一端进行插入,在另一端进行删除的线性表。
队列中允许插入的一端称为队尾,允许删除的一端称为对头。通常用两根指针指示他们的位置。如:
对头 队尾
----------------------------------------
出队<---| A0 | A1 | A2 | A3 | …… |An |<--入队
----------------------------------------
front rear
在队尾插入数据元素的操作称为入队。在对头删除数据元素的操作称为出队。入队时,只涉及队尾指针的变化;出队时,只涉及对头指针的变化。
对队列中没有数据元素的时候,称为空对(front=rear)
队列的特点是“先进先出”(First In First Out,FIFO),即先入队的数据元素先出队。因此队列又被称为先进先出的线性表。(栈的特点是先进后出/后进先出)
队列的抽象数据模型
队列的抽象数据模型表示了队列中的数据元素、数据元素之间的逻辑关系以及对队列的操作的集合
ADT Queue
数据元素集合:
具有相同性质数据元素的一个有限序列,且只能在称为队尾的一端进行插入操作和在对头一端进行删除操作。
基本操作:
初始化队列(initqueue) :初始化
求队列长度(QueueLength):获取队列中的数据元素个数
入队(EnterQueue) :在队尾插入新的数据元素
出队(DeleteQueue) :删除对头数据元素
取对头元素(GetHead) :获取对头的数据元素值
判断空队(QueueEmpty) :判断队是否为空队列
清空队列(ClearQueue) :清空队列
销毁队列(DestroyQueue) :销毁队列
用顺序存储方式实现的队列称为顺序队列。与顺序表类似,队列中的数据元素依次存储在地址连续的存储空间中,并用对头指针指向对头元素,用队尾指针指向队尾元素的下一个位置。
入队操作步骤:新元素插入队尾所指的位置;队尾指针增一,指向新的位置。
出队操作步骤:对头元素出队,对头指针增一。
- [somniumchase] 我一运行就说没有数字 01/01 11:44
- [游客] 为什么啊 08/07 15:36
- [游客] 如果想快一些 就改下面这里 dx值改成1H delay: push ax 04/19 02:53
- [lshhjx] 注释在程序中很重要,楼主不知道吗? 12/08 13:40
- [biaggi] 看不明白,在下還須學習 11/06 08:11
- [游客] 我运行的时候直接显示Unkown filename跳出了- -请问怎么改 06/16 21:44
- [游客] 勿庸置疑,注释是好习惯。与人方便自己方便。 04/12 10:33
- [游客] 老实说,看着真心累呀! 04/07 18:37
- [游客] 很无语,初学者就多看书,不要动不动要别人注释,基础打好了,再自己注释,这样比别人帮你注释好得多 12/17 19:43
- [dgkepu] 初学者:不懂,希望有多点注释带着学习学习! 12/07 20:52
- [游客] windows 7是一个64Bit操作系统,它不兼容DOS,无法识别16Bit系统。重装系统wind 02/28 21:05
- [游客] windows 7是一个64Bit操作系统,它不兼容DOS,无法识别16Bit系统。重装系统wind 02/28 21:05
- [466987333] 你好,高手,我想请教一个问题。 我用的是win7操作系统,32位的,里面没有找masm目录,是不是 12/12 17:30
- [lanfioncc] 那个太高级了。。。我还有点看不懂。。不过谢谢!!! 11/27 11:23
- [yc2010] 实验16中的 table: dw sub1,sub2,sub3,sub4 可不可以改成呢? 09/11 09:08
- [yc2010] mov bl,ah mov bh,0 add bx,bx ----------->这里为 09/07 21:03
- [yc2010] 为什么要add bx,bx呢? 09/07 20:55
- [yc2010] 那是不是像table[bx],ds[bx]....等(内存单元)都是表示一个字节呢? 09/06 21:10
- [masmaster] 杨季文的《80X86汇编语言程序设计教程》 09/01 12:52
- [游客] to masmaster shl左移4位,那al传进来的4,5,6位背景色不就没了. 为什 09/01 11:00
[ 1013651933 发表于 2011-04-26 22:08 ]
要给点具体的实例就漂亮了,光看貌似不管用啊。
[ zaixuexi 发表于 2011-04-27 09:51 ]
那只是你不熟练而已,用C或者用汇编都很简单就能实现