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 queueA 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 queuesIf 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 4. Implementationclass 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:
|
<<: The most commonly used HTML tags to create web pages
>>: Use CSS to switch between dark mode and bright mode
This article shares with you the MySQL 8.0.17 ins...
Table of contents background CommonsChunkPlugin s...
1. Getting started with setUp Briefly introduce t...
Mysql is a mainstream open source relational data...
1. Introduction to docker-maven-plugin In our con...
Detailed explanation and summary of the URL for d...
I worked in operations and maintenance for two ye...
When the system encounters various IO bottlenecks...
Mini Program Data Cache Related Knowledge Data ca...
MySql 8.0 corresponding driver package matching A...
1. Requirements description Display the delete ic...
I won’t waste any more time talking nonsense, let...
Use js to control the light switch for your refer...
Preface Every good habit is a treasure. This arti...
Personal implementation screenshots: Install: npm...