队列也是列表的一种,有不同于列表的规则。

  1. 先进先出
  2. 入队方法
  3. 出队方法
  4. 可以找到队首
  5. 可以找到队尾
  6. 可以查看队列有多长
  7. 可以查看队列是否为空

这是一个基本的需求,围绕他来实现,当然我们可以自己扩展列表的规则并辅以代码实现

queue.js

  1. /**
  2. * 队列,先进先出 First-In-First-Out
  3. * 入队 出队
  4. * @constructor
  5. */
  6. function Queue(){
  7. this.dataStore=[];
  8. this.count = length;
  9. this.clear = clear;
  10. this.enqueue = enqueue;
  11. this.dequeue = dequeue;
  12. this.front = front;
  13. this.back = back;
  14. this.toString = toString;
  15. this.empty = empty;
  16. /**
  17. * 队列数量
  18. * @returns {Number}
  19. */
  20. function length(){
  21. return this.dataStore.length;
  22. }
  23. /**
  24. * 清空队列
  25. */
  26. function clear(){
  27. this.dataStore = [];
  28. }
  29. /**
  30. * 查询队列是否为空
  31. * @returns {boolean}
  32. */
  33. function empty() {
  34. if (this.dataStore.length == 0) {
  35. return true;
  36. }
  37. else {
  38. return false;
  39. }
  40. }
  41. /**
  42. * 入列
  43. * @param element
  44. */
  45. function enqueue(element){
  46. this.dataStore.push(element)
  47. }
  48. /**
  49. * 出列
  50. * @returns {*}
  51. */
  52. function dequeue(){
  53. return this.dataStore.shift();
  54. }
  55. /**
  56. * 队尾
  57. * @returns {*}
  58. */
  59. function back() {
  60. return this.dataStore[this.dataStore.length-1];
  61. }
  62. /**
  63. * 队首
  64. * @returns {*}
  65. */
  66. function front(){
  67. return this.dataStore[0]
  68. }
  69. /**
  70. * 返回队列所有元素
  71. * @returns {string}
  72. */
  73. function toString(){
  74. var s = '';
  75. for(var i=0;i<this.dataStore.length;i++){
  76. s+= this.dataStore[i]+'\n'
  77. }
  78. return s;
  79. }
  80. }
  81. window.Queue = Queue

队列的实现 -- 数据结构与算法的javascript描述 第五章的更多相关文章

  1. 检索算法 -- 数据结构与算法的javascript描述 第13章

    检索算法-如何在列表中查找特定的值. 顺序查找 从列表的第一个元素开始对列表元素逐个进行判断,直到找到了想要的结果,它属于暴力查找技巧的一种,在执行查找时可能会访问到数据结构里的所有元素. 代码: / ...

  2. 排序算法 -- 数据结构与算法的javascript描述 第12章

    排序是常见的功能,给定一组数据,对其进行排序. 在此之前,我们需要准备个基础工作--自动生成数组,并可以对该组数据做任何处理. /** * 测试类 ,数组 * @param numElements * ...

  3. 字典 -- 数据结构与算法的javascript描述 第七章

    字典 字典是一种以键-值对形式存储数据的数据结构 最基本功能规划 add 添加数据到字典 remove 从字典中移除数据 get 从字典中取出数据 count 统计字典数据量 find 查找数据在字典 ...

  4. 链表的实现 -- 数据结构与算法的javascript描述 第六章

    链表 链表是由一组节点组成的集合.每个节点都使用一个对象的引用指向它的后继.指向另一个节点的引用叫做链 结构示意图 : 链表头需要我们标识 head { element:head,next:obj1 ...

  5. 栈的实现 -- 数据结构与算法的javascript描述 第四章

    栈 :last-in-first-out 栈有自己特殊的规则,只能 后进入的元素 ,最先被推出来,我们只需要模拟这个规则,实现这个规则就好. peek是返回栈顶元素(最后一个进入的). /** * 栈 ...

  6. 散列表的实现 -- 数据结构与算法的javascript描述 第八章

    散列表(哈希表 散列是一种常用的数据存储技术,散列后的数据可以快速地插入或取用. 散列表需要一个散列值(key)来存储指定数据,取数据也是依靠此. 散列值可以依靠计算数据的 ASCII码来获得,但是这 ...

  7. 二叉树的实现 -- 数据结构与算法的javascript描述 第十章

    /** * 树,一种非线性的数据结构. 以分层的方式存储数据. * 一棵树最上面的节点成为根节点,如果一个节点下面有多个节点,这个节点称为父节点,下面的节点称为子节点 * 没有任何子节点的节点,陈宝国 ...

  8. 集合的实现 -- 数据结构与算法的javascript描述 第九章

    集合 集合(set)是一种包含不同元素的数据结构. 集合中的元素称为成员. 集合的两个最重要特性是:首先,集合中的成员是无序的:其次,集合中不允许相同成员存在. code function Set() ...

  9. 列表的实现-----数据结构与算法JavaScript描述 第三章

    实现一个列表 script var booklist = new List(); booklist.append('jsbook'); booklist.append('cssbook'); book ...

随机推荐

  1. SQL Server创建LinkServer

    USE [master] GO /****** Object: LinkedServer [xxx_LNK] Script Date: 2014/7/7 17:04:13 ******/ EXEC m ...

  2. JQuery window、document、 body

    我电脑屏幕分辨率:1440 * 900   最大化浏览器,刷新浏览器 alert($(window).width() + "---" + $(window).height()); ...

  3. Keli Linux与网络安全(2)——初探Keli

    Kali是BackTrack的升级换代产品,按照官方网站的定义,Kali Linux是一个高级渗透测试和安全审计Linux发行版.作为使用者,我简单的把它理解为,一个特殊的Linux发行版,集成了精心 ...

  4. HTML5 javascript实现音乐播放器

    准备毕业了,感觉好多东西都没学会,太多太多想学的知识,有种求知若渴的状态. 四年的大学就剩下一个多月了,无论将来多么困难,这条路是自己选的,走就要走的精彩! 自学了一点javascript.php,做 ...

  5. java操作mysql的增删改查

    prepareStatement(sql)是statement的子类,比statement好用. 如果数据库中定义的是int值,那么sql语句中要把int单独提出来.如".....value ...

  6. AjaxPro.dll,asp.net 前台js调用后台方法(无刷新)

    1.什么是Ajax Ajax是异步Javascript和XML(Asynchronous JavaScript and XML)的英文缩写."Ajax"这个名词的发明人是Jesse ...

  7. bind新发现

    function foo(a,b){ this.val = a+b; } var bar = foo.bind(null, 'p1'); var baz = new bar('p2'); consol ...

  8. 复习day12-23

    获取请求中的内容: request.getParameter(); get方式因为在地址栏所以需要转码: String name = new String(req.getparameter().get ...

  9. Unity 绘制多边形

    最近工程需要用到一个多边形用来查看角色属性,于是就研究了下Mesh用网格做了一个.遗憾的的 UGUI 渲染不了 3D 物体,然后又用了一段时间研究了下UGUI的网格绘制. 不过终于还是完成了,虽然有些 ...

  10. linux下创建用户并且限定用户主目录

    Linux 系统是一个多用户多任务的分时操作系统,任何一个要使用系统资源的用户,都必须首先向系统管理员申请一个账号,然后以这个账号的身份进入系统.用户的账号 一方面可以帮助系统管理员对使用系统的用户进 ...