JavaScript implements double-ended queue

JavaScript implements double-ended queue

This article example shares the specific code of javascript to implement double-ended queues for your reference. The specific content is as follows

1. Double-ended queue

A deque is a special queue that allows us to add and remove elements from both the front and back ends at the same time.

2. Application of double-ended queues

If a person who has just bought a ticket needs to ask some simple information, he can go back to the head of the line. If the person at the end of the line is in a hurry, he can leave the line.

3. Double-ended queue method

addFront(element): This method adds a new element to the front of the double-ended queue
addBack(element): This method adds a new element to the back end of the double-ended queue (the implementation method is the same as the enqueue method in the Queue class).
removeFront(): This method removes the first element from the front of the double-ended queue
removeBack(): This method removes the first element from the back end of the double-ended queue
peekFront(): This method returns the first element of the double-ended queue.
peekBack()): This method returns the first element at the back end of the double-ended queue.

4. Implementation

class Deque{
           constructor(){
               this.items = {};
               this.count = 0;
               this.lowestCount = 0; 
           }

        // Add a new element to the front of the double-ended queue addFront(element){
            if(this.isEmpty()){
                this.addBack(element);
            }
            else if(this.lowestCount > 0){
                this.lowestCount --;
                this.items[this.lowestCount] = element;
            }
            else{
                for(let i=this.count;i>0;i--){
                    this.items[i] = this.items[i-1]; 
                }
                this.lowestCount = 0;
                this.items[this.lowestCount] = element;
                this.count++;
            }
        };
        addBack(element){
            this.count++;
            this.items[this.count-1] = element;
        };
        removeFront(){
            if(this.isEmpty()){
                return undefined;
            }
            const result = this.items[this.lowestCount];
            delete this.items[this.lowestCount];
            this.lowestCount++;
            return result;
        };
        removeBack(){
            if(this.isEmpty()){
                return undefined;
            }
            const result = this.items[this.count-1];
            delete this.items[this.count-1];
            this.count--;
            return result;
        };
        peekFront(){
            if(this.isEmpty()){
                return null;
            }
          return this.items[this.lowestCount];
        };
        peekBack(){
            if(this.isEmpty()){
                return null;
            }
            return this.items[this.count-1];
        };
        isEmpty(){
            return this.count - this.lowestCount == 0;
        }
        size(){
            return this.count - this.lowestCount;
        }
        toString(){
            if(this.isEmpty()){
                return '';
            }
            let objString = `${this.items[this.lowestCount]}`;
            for(var i=this.lowestCount+1;i<this.count;i++){
                objString = `${objString},${this.items[i]}`;
            }
            return objString;
        }
        clear(){
            this.items={};
            this.count = 0;
            this.lowestCount = 0;
        }
   

       }

       const deque = new Deque();
       deque.addFront('John');
       deque.addFront('Jack');
       deque.addFront('Amy');
       deque.addBack('Lisa');
    // deque.removeFront();
    // deque.removeBack();
    console.log(deque.size());
    console.log(deque.toString());
    console.log(deque);
    console.log(deque.isEmpty());
       console.log(deque.clear());
       console.log(deque);

The above is the full content of this article. I hope it will be helpful for everyone’s study. I also hope that everyone will support 123WORDPRESS.COM.

You may also be interested in:
  • Detailed implementation and application of queues and double-ended queues in JS
  • Write an event queue operation function in js
  • Detailed explanation of the stack method and queue method of JavaScript array
  • JS implementation of queue and stack method
  • Detailed explanation of JavaScript queue functions and asynchronous execution
  • Detailed explanation of the queue example in JS algorithms and data structures
  • JS implementation of queue first-in-first-out function example
  • Circular queue code implemented using array in javascript
  • JavaScript queues, priority queues and circular queues
  • JS implements a method of using two queues to represent a stack

<<:  The most commonly used HTML tags to create web pages

>>:  Use CSS to switch between dark mode and bright mode

Recommend

MySQL 8.0.17 installation graphic tutorial

This article shares with you the MySQL 8.0.17 ins...

Implementation of webpack code fragmentation

Table of contents background CommonsChunkPlugin s...

The complete usage of setup, ref, and reactive in Vue3 combination API

1. Getting started with setUp Briefly introduce t...

MySQL concurrency control principle knowledge points

Mysql is a mainstream open source relational data...

Teach you how to use docker-maven-plugin to automate deployment

1. Introduction to docker-maven-plugin In our con...

Detailed explanation and summary of the URL for database connection

Detailed explanation and summary of the URL for d...

Summary of some of my frequently used Linux commands

I worked in operations and maintenance for two ye...

A brief introduction to Linux performance monitoring commands free

When the system encounters various IO bottlenecks...

Application and implementation of data cache mechanism for small programs

Mini Program Data Cache Related Knowledge Data ca...

Notes on matching MySql 8.0 and corresponding driver packages

MySql 8.0 corresponding driver package matching A...

HTML+CSS makes div tag add delete icon in the upper right corner sample code

1. Requirements description Display the delete ic...

Detailed explanation of meta tags and usage in html

I won’t waste any more time talking nonsense, let...

Control the light switch with js

Use js to control the light switch for your refer...

21 MySQL standardization and optimization best practices!

Preface Every good habit is a treasure. This arti...

Use vue to implement handwritten signature function

Personal implementation screenshots: Install: npm...