Stack-Implementierung mit Javascript (verlinkte Liste)

王林
Freigeben: 2024-08-14 17:19:52
Original
224 Leute haben es durchsucht

Stack Implementation Using Javascript (Linked List)

Einführung

Wenn Sie sich nicht sicher sind oder mehr über verknüpfte Listen und ihre Typen und darüber erfahren möchten, wie wir Operationen daran durchführen können, lesen Sie bitte meinen anderen Artikel über die einfach verknüpfte Liste und die doppelt verknüpfte Liste

Annäherung an einfach und doppelt verknüpfte Listen mit Javascript bei allen Vorgängen: - Last-Stop-Lösung

  1. In diesem Artikel geht es um die Verwendung der Single Linked List und die Erstellung einerStack-Datenstruktur.

Wenn Sie Bedenken haben, können Sie sich gerne an mich wenden

Viel Spaß beim Coden, viel Spaß beim Programmieren.

class Node { constructor(value) { this.value = value; this.next = null; } } class LinkedList { constructor() { this.head = this.tail = null; this.size = 0; } append(value) { const newNode = new Node(value); if (this.head === null) { console.log('Inside strange') this.head = this.tail = newNode; this.size = 1; return; } this.tail.next = newNode; this.tail = newNode; this.size++; } deletAtEnd() { if (this.size <= 1) { this.head = this.tail = null; this.size = 0; return; } let currentNode = this.head; const pos = this.size -1; let counter = 1; while (currentNode) { if (counter++ === pos) { currentNode.next = null; this.tail = currentNode; this.size--; return ; } currentNode = currentNode.next; } } traversal() { let currentNode = this.head; while (currentNode) { console.log(currentNode.value); currentNode = currentNode.next; } } reverse() { let currentNode = this.head; let prevNode = null; let nextNode = null; while (currentNode) { nextNode = currentNode.next; currentNode.next = prevNode; if (prevNode === null) { this.tail = currentNode; } prevNode = currentNode; currentNode = nextNode; } this.head = prevNode; this.traversal(); } } class Stack { stack; constructor() { this.stack = new LinkedList(); } push(value) { this.stack.append(value); } pop() { this.stack.deletAtEnd() } peak() { console.log('Peak Value ---> ', this.stack.tail.value); } traversal() { this.stack.reverse(); } } const test = new Stack(); test.push(20); test.push(13); test.push(3); test.push(5); test.push(9); console.log(test.stack) console.log('---------------Peak-------------') test.peak() console.log('-------------After Pop ------------'); test.pop(); test.peak() test.traversal() /* LinkedList { tail: Node { value: 9, next: null }, head: Node { value: 20, next: Node { value: 13, next: [Node] } }, size: 5 } ---------------Peak------------- Peak Value ---> 9 -------------After Pop ------------ Peak Value ---> 5 5 3 13 20 */
Nach dem Login kopieren

Das obige ist der detaillierte Inhalt vonStack-Implementierung mit Javascript (verlinkte Liste). Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:dev.to
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage
Über uns Haftungsausschluss Sitemap
Chinesische PHP-Website:Online-PHP-Schulung für das Gemeinwohl,Helfen Sie PHP-Lernenden, sich schnell weiterzuentwickeln!