zoukankan      html  css  js  c++  java
  • 使用javaScript实现一个队列

    1.队列是遵循先进先出(FIFO)原则的一组有序的项,队列在尾部添加元素,并从顶部移除元素,最新添加的元素必须排在队列的末尾。生活中常见的例子如排队等。

    2.创建一个队列类

    class Queue{
        constructor(){
            this.count = 0;//记录队列的数量
            this.lowestCount = 0;//记录当前队列头部的位置
            this.items = [];//用来存储元素。
        }
    }

    3.添加元素

      enqueue(element){
            this.items[this.count] = element;
            this.count++;
        }

    4.删除元素(只删除队列头部)

        dequeue(){
            if(this.isEmpty()){
                return 'queue is null';
            }
            let resulte = this.items[this.lowestCount];
            delete  this.items[this.lowestCount];
            this.lowestCount++;
            return resulte;
        }

    5.查看队列头部元素

        peek(){
            return this.items[this.lowestCount];
        }

    6.判断队列是否为空

        isEmpty(){
            return this.count - this.lowestCount === 0;
        }

    7.清除队列的元素

        clear(){
            this.count = 0;
            this.lowestCount = 0;
            this.items = [];
        }

    8.查看队列的长度

     size(){
            return this.count - this.lowestCount;
        }

    9.查看队列的所有内容

      toString(){
            if(this.isEmpty())return "queue is null";
            let objString = this.items[this.lowestCount];
            for(let i = this.lowestCount+1; i < this.count;i++){
                objString = `${objString},${this.items[i]}`;
            }
            return objString;
        }

    10.完整代码

    class Queue{
        constructor(){
            this.count = 0;//记录队列的数量
            this.lowestCount = 0;//记录当前队列顶部的位置
            this.items = [];//用来存储元素。
        }
        enqueue(element){
            this.items[this.count] = element;
            this.count++;
        }
        dequeue(){
            if(this.isEmpty()){
                return 'queue is null';
            }
            let resulte = this.items[this.lowestCount];
            delete  this.items[this.lowestCount];
            this.lowestCount++;
            return resulte;
        }
        peek(){
            return this.items[this.lowestCount];
        }
        isEmpty(){
            return this.count - this.lowestCount === 0;
        }
        size(){
            return this.count - this.lowestCount;
        }
        clear(){
            this.count = 0;
            this.lowestCount = 0;
            this.items = [];
        }
        toString(){
            if(this.isEmpty())return "queue is null";
            let objString = this.items[this.lowestCount];
            for(let i = this.lowestCount+1; i < this.count;i++){
                objString = `${objString},${this.items[i]}`;
            }
            return objString;
        }
    }

    11.运行结果

  • 相关阅读:
    朴灵:基于MongoDB与NodeJS构建物联网系统
    平均年薪40万!为什么却很少见程序员炫富?
    写春联、变魔术、模仿马云唱歌_为你揭秘阿里云人工智能ET背后的技术
    Mysql查询性能优化-善用Explain语句
    numpy linspace arange函数
    vim笔记
    redis压缩列表
    tensorflow笔记之反向传播时用到的几种方法
    损失函数
    kafka 修改partition,删除topic,查询offset
  • 原文地址:https://www.cnblogs.com/MySweetheart/p/13211539.html
Copyright © 2011-2022 走看看