zoukankan      html  css  js  c++  java
  • 线性结构_队列

    队列结构

              队列结构(Queue)    一种受限的线性结构

      1. 特点

                    1. 队列是一种受限的线性结构

                    2. 先进先出,后进后出

                    3. 在前端插入,在后端弹出

      2. 队列的应用

                    1. 打印队列

                        打印机取出一个打印一个,直到所有文档被打印

                    2. 线程队列

                        多任务的并行处理时,将所有的人物放入队列,依次启动线程进行处理

      3. 队列的实现

                    基于数组

                    基于链表

      4. 队列的方法

                    1. enqueue(element)     向队列尾部添加一个(或多个)元素

                    2. dequeue()            从队列头部移除一个元素并返回

                    3. front()              返回队列中的第一个元素,此时队列没有被修改

                    4. isEmpty()            判断队列是否为空

                    5. size()               反对队列长度,即队列中元素的个数

                    6. toString()           将队列中的元素转成字符串并返回

      5. 队列的代码实现

    function Queue(){
            // 队列的属性
            this.items = [];
    
            // 队列的方法
            // 1. 向队列尾部添加一个(或多个)元素
            Queue.prototype.enqueue = function(element){
                this.items.push(element);
            }
    
            // 2. 从队列头部移除一个元素并返回
            Queue.prototype.dequeue = function(){
                return this.items.shift();
            }
    
            // 3. 返回队列中的第一个元素,此时队列没有被修改
            Queue.prototype.front = function(){
                return this.items[0];
            }
    
            // 4. 判断队列是否为空
            Queue.prototype.isEmpty = function(){
                return this.items.length == 0;
            }
    
            // 5. 返回队列长度,即队列中元素的个数
            Queue.prototype.size = function(){
                return this.items.length;
            }
    
            // 6. 将队列中的元素转成字符串并返回
            Queue.prototype.toString = function(){
                var res = "";
                for(var i = 0; i < this.items.length; i++){
                    res += this.items[i] + " ";
                }
                return res;
            }
       }
    View Code

  • 相关阅读:
    [笔记] Duke
    foxmail配置office365邮箱
    bootstrap-select and selectpicker 修改下拉框的宽度或者下方留白
    项目技术沉淀0
    alibaba开发手册
    关于fastjson
    org.springframework.jdbc.UncategorizedSQLException: ### Error updating database. Cause: java.sql.SQLException: Incorrect string value: 'xE2x80x8BxE2x80x8B...' for column 'pro_backgroud' at row
    datatable某列不排序、和自定义搜索、给数据里面加属性
    19.10.30笔记-文件下载
    没有图片的freemarker下载,备份
  • 原文地址:https://www.cnblogs.com/carreyBlog/p/13657016.html
Copyright © 2011-2022 走看看