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.运行结果

  • 相关阅读:
    转 C#接收邮件
    WebApi的windows服务之路
    自动化升级工具之客户端升级工具之windows服务升级操作
    自动化升级工具之客户端升级工具之数据库升级操作
    GoJs实现流程管理图
    MvcForum作者称该项目进入缓慢更新
    生鲜蔬菜生产称重管理系统
    MvcForum中文版+PostgreSql源码下载
    Asp.Net MVC开源论坛中文版
    HTML5+Activex+Singr+ABP+MongoDB
  • 原文地址:https://www.cnblogs.com/MySweetheart/p/13211539.html
Copyright © 2011-2022 走看看