栈和队列是在软件设计中常用的两种数据结构,它们的逻辑结构和线性表相同。
其特点在于运算受到了限制:
栈(Stack)是一个后进先出(Last in first out,LIFO)的线性表,它要求只在表尾进行删除和插入操作。
队列“先进先出”的规则进行操作,故称运算受限制的线性表。
当然受存储方式的影响可以分顺序,链存储,erlang这样的语言实现不了链,接下来的分析操作都是用lists,queue 来的。
erlang队列结构
queue :
{[],[]} queue使用两个list来实现,这两个List为{RearList,FrontList} 即{尾端,前端},queue的第一个元素出现在FrontList,
erlang的队列为什么要分成两个list来处理呢,其实是为了保证回去队尾元素的操作时间复杂度上,queue的最后一个元素出现在RearList的Head,这样在取得队尾:[HEnd|T] 操作O(1) 若是就用单列表获取队尾O(n)(n为列表长度)
感兴趣可以看下坚强哥的博客对queue的分析:http://www.cnblogs.com/me-sa/archive/2012/07/10/erlang-queue.html
队列代码如下:
%% Copyright
-module(stack_queue).
-author("sugar").
%% <