Table des matières
Introduction au problème
Ajouter un nœud au début de la liste chaînée
Exemple
Ajouter un nœud au milieu de la liste chaînée
Ajouter un nœud à la fin de la liste chaînée
Conclusion
Maison interface Web js tutoriel Programme JavaScript pour insérer des nœuds dans une liste chaînée

Programme JavaScript pour insérer des nœuds dans une liste chaînée

Sep 21, 2023 pm 10:33 PM

在链表中插入节点的 JavaScript 程序

Une liste chaînée est une structure de données de différentes longueurs, n'importe quel nœud peut être supprimé ou ajouté à la liste chaînée. Dans ce tutoriel, nous allons implémenter un programme complet pour insérer des nœuds dans une liste chaînée avec une complexité spatiale et temporelle. Comprenons d’abord l’énoncé du problème.

Introduction au problème

Dans la question donnée, on nous donne une liste chaînée et comme nous pouvons modifier la taille de la liste chaînée en ajoutant ou en supprimant des nœuds dans la liste chaînée, nous ajouterons ou insérerons des nœuds dans la liste chaînée.

Dans une liste chaînée, nous pouvons ajouter de nouveaux nœuds à trois emplacements différents : au début, après le dernier nœud et au milieu de la liste. Par exemple, la liste chaînée donnée est -

1 -> 2 -> 3 -> 4 -> 5 -> null, nous devons ajouter un nœud aléatoire de valeur 9. Par conséquent, il existe de nombreux cas où des nœuds doivent être ajoutés, tels que -

  • Ajouter un nœud au début - 7 -> 1 -> 2 -> 3 -> 4 -> 5 -> null

  • Ajouter un nœud au milieu - 1 -> 2 -> 3 -> 7 -> 4 -> 5 -> null

  • Ajouter un nœud à la fin - 1 -> 2 -> 3 -> 4 -> 5 -> 7 -> null

Regardons les moyens d'accomplir les tâches suivantes -

Ajouter un nœud au début de la liste chaînée

Exemple

Pour ajouter un nœud au début de la liste chaînée, nous devons créer un nouveau nœud et passer la tête de la liste chaînée au nouveau nœud comme nœud suivant, puis déplacer la tête vers le nouveau nœud et ajouter le nouveau nœud nœud au début de la liste chaînée.

// creating the linked list node
class Node {
   constructor(data) {
      this.value = data;
      this.next = null;
   }
}
function push(tail, data){
   var new_node = new Node(data);
   tail.next = new_node;
   tail = tail.next;
   return tail
}
function add(data) {
   var new_node = new Node(data);
   new_node.next = head;
   return new_node;
}

var head = new Node(1);
var tail = head;
tail = push(tail, 2)
tail = push(tail, 3)
tail = push(tail, 4)
tail = push(tail, 5)

head = add(7);
var data = 0;
while(head != null) {
   data = data + head.value + " -> ";
   head = head.next;
}
console.log("Linked List after adding a node at starting: ")
console.log(data + "null")
Copier après la connexion

La complexité temporelle du code ci-dessus est O(1), car il suffit de déplacer un pointeur et aucun espace supplémentaire n'est utilisé, ce qui rend la complexité spatiale O(1).

Ajouter un nœud au milieu de la liste chaînée

Exemple

Pour ajouter un nœud au milieu d'une liste chaînée, nous devons créer un nouveau nœud et transmettre ce nœud avant de pouvoir ajouter le nouveau nœud de la liste chaînée comme nœud suivant du nouveau nœud, cela ajoutera le nouveau nœud nœud à la liste chaînée au milieu.

// creating the linked list node
class Node {
   constructor(data) {
      this.value = data;
      this.next = null;
   }
}
function push(tail, data) {
   var new_node = new Node(data);
   tail.next = new_node;
   tail = tail.next;
   return tail
}
function add(data,head) {
   var new_node = new Node(data);
   var temp = head;
   while(temp.value != 3) {
      temp  = temp.next;
   }
   new_node.next = temp.next;
   temp.next = new_node;
   return head;
}
var head = new Node(1);
var tail = head;
tail = push(tail, 2)
tail = push(tail, 3)
tail = push(tail, 4)
tail = push(tail, 5)
head = add(7,head);
var data = 0;
while(head != null) {
   data = data + head.value + " -> ";
   head = head.next;
}
console.log("Linked List after adding node in middle:")
console.log(data + "null")
Copier après la connexion

La complexité temporelle du code ci-dessus est O(N) car nous devons nous déplacer vers le nœud où un nouveau nœud doit être ajouté. La complexité spatiale du processus ci-dessus est O(1) puisque nous n'utilisons aucun espace supplémentaire.

Ajouter un nœud à la fin de la liste chaînée

Exemple

Pour ajouter un nœud à la fin de la liste chaînée, nous devons créer un nouveau nœud et ajouter ce nœud après le nœud de queue et déplacer le nœud de queue vers le nœud suivant.

// creating the linked list node
class Node {
   constructor(data) {
      this.value = data;
      this.next = null;
   }
}
function push(tail, data) {
   var new_node = new Node(data);
   tail.next = new_node;
   tail = tail.next;
   return tail
   }

function add(data) {
   var new_node = new Node(data);
   tail.next = new_node;
   tail = tail.next
   return tail;
}
var head = new Node(1);
var tail = head;
tail = push(tail, 2)
tail = push(tail, 3)
tail = push(tail, 4)
tail = push(tail, 5)

tail = add(7);
var data = 0;
while(head != null){
   data = data + head.value + " -> ";
   head = head.next;
}
console.log("Linked List after adding a node at the end: ")
console.log(data + "null")
Copier après la connexion

La complexité temporelle du code ci-dessus est O(1), car il suffit de déplacer un pointeur et aucun espace supplémentaire n'est utilisé, ce qui rend la complexité spatiale O(1).

Conclusion

Dans le didacticiel ci-dessus, nous avons appris comment ajouter un nouveau nœud dans une liste chaînée existante de trois manières possibles. Nous avons vu du code correct avec des explications et des complexités temporelles et spatiales. L'ajout d'un nœud au milieu de la liste chaînée prend un temps O(N), tandis que pour les deux autres cas, sa complexité temporelle est O(1), et pour les trois possibilités, la complexité spatiale est O(1).

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

Article chaud

Musée de deux points: Guide de localisation de Bungle Wasteland
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Combien de temps faut-il pour battre Split Fiction?
3 Il y a quelques semaines By DDD
Repo: Comment relancer ses coéquipiers
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: Comment obtenir des graines géantes
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌

Article chaud

Musée de deux points: Guide de localisation de Bungle Wasteland
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Combien de temps faut-il pour battre Split Fiction?
3 Il y a quelques semaines By DDD
Repo: Comment relancer ses coéquipiers
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: Comment obtenir des graines géantes
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌

Tags d'article chaud

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Remplacer les caractères de chaîne en javascript Remplacer les caractères de chaîne en javascript Mar 11, 2025 am 12:07 AM

Remplacer les caractères de chaîne en javascript

jQuery Vérifiez si la date est valide jQuery Vérifiez si la date est valide Mar 01, 2025 am 08:51 AM

jQuery Vérifiez si la date est valide

jQuery obtient un rembourrage / marge d'élément jQuery obtient un rembourrage / marge d'élément Mar 01, 2025 am 08:53 AM

jQuery obtient un rembourrage / marge d'élément

Plugins JS de manipulation de 5 premiers Plugins JS de manipulation de 5 premiers Feb 28, 2025 am 12:34 AM

Plugins JS de manipulation de 5 premiers

10 onglets jQuery Accordion 10 onglets jQuery Accordion Mar 01, 2025 am 01:34 AM

10 onglets jQuery Accordion

10 vaut la peine de vérifier les plugins jQuery 10 vaut la peine de vérifier les plugins jQuery Mar 01, 2025 am 01:29 AM

10 vaut la peine de vérifier les plugins jQuery

jQuery Ajouter une barre de défilement à div jQuery Ajouter une barre de défilement à div Mar 01, 2025 am 01:30 AM

jQuery Ajouter une barre de défilement à div

Http débogage avec le nœud et le http-console Http débogage avec le nœud et le http-console Mar 01, 2025 am 01:37 AM

Http débogage avec le nœud et le http-console

See all articles