Table des matières
Algorithme
Exemple : implémentez l'algorithme ci-dessus à l'aide de JavaScript
Conclusion
Maison interface Web js tutoriel Programme JavaScript pour rechercher des éléments dans une liste chaînée

Programme JavaScript pour rechercher des éléments dans une liste chaînée

Sep 02, 2023 pm 05:45 PM

用于在链接列表中搜索元素的 JavaScript 程序

Une liste chaînée est une structure de données linéaire dans laquelle chaque élément (également appelé nœud) contient une valeur de données et une référence au nœud suivant de la liste. Une opération courante sur une liste chaînée consiste à rechercher un élément spécifique. Cela implique de parcourir la liste et de comparer la valeur des données de chaque nœud à l'élément cible jusqu'à ce qu'une correspondance soit trouvée.

Voici un exemple de la liste de liens que nous utiliserons tout au long de cet article -

10 -> 20 -> 30 -> 40 -> Vide

Dans cette liste chaînée, chaque nœud contient une valeur et la flèche indique le nœud suivant dans la séquence. La liste commence par le nœud principal, qui contient la valeur 10, et se termine par le nœud final, qui contient la valeur 40 et pointe vers null. Nous utiliserons cette liste chaînée pour montrer comment rechercher un élément dans une liste chaînée à l'aide de JavaScript.

Voyons l'exemple ci-dessous -

Linked list: 10 -> 20 -> 30 -> 40 -> null
Input: 40
Output: Element found at index 3
Input: 10
Output: Element found at index 0
Input: null
Output: Element not found
Copier après la connexion

Parlons maintenant de l'algorithme de création de listes chaînées en JavaScript.

Algorithme

Étape 1 - Définissez une classe Node avec deux propriétés : value et next. L'attribut value représente les données stockées dans le nœud et l'attribut suivant est une référence au nœud suivant dans la liste chaînée.

Étape 2 - Définissez une classe LinkedList avec trois propriétés : head, tail et length. L'attribut head représente le premier nœud de la liste chaînée, l'attribut tail représente le dernier nœud de la liste chaînée et l'attribut length représente le nombre de nœuds dans la liste chaînée.

Étape 3 - Définir une méthode nommée - ajouter à la classe LinkedList qui prend une valeur comme paramètre. La méthode add doit créer un nouveau nœud avec la valeur donnée et l'ajouter à la fin de la liste chaînée.

Étape 4 - Définissez une méthode appelée "remove" pour la classe LinkedList qui prend une valeur comme paramètre. La méthode Remove doit supprimer le premier nœud avec une valeur donnée dans la liste chaînée.

Étape 5 - Définissez une méthode appelée recherche pour la classe LinkedList qui prend une valeur comme paramètre. La méthode de recherche doit renvoyer le premier nœud de la liste chaînée avec la valeur donnée, ou null si le nœud n'est pas trouvé.

Étape 6 - Définissez une méthode appelée reverse pour la classe LinkedList, qui est utilisée pour inverser l'ordre des nœuds dans la liste chaînée.

Exemple : implémentez l'algorithme ci-dessus à l'aide de JavaScript

Le programme suivant définit une classe Node et une classe LinkedList. La classe Node crée un nouveau nœud en utilisant la valeur de données donnée et une référence au nœud suivant dans la liste. La classe LinkedList crée une nouvelle liste chaînée avec le nœud principal pointant initialement vers null et la propriété size définie sur 0. La méthode add ajoute un nouveau nœud à la fin de la liste chaînée. La méthode de recherche parcourt la liste chaînée et renvoie l'index de l'élément s'il est trouvé, ou un message s'il n'est pas trouvé. Enfin, le programme crée une nouvelle liste chaînée, y ajoute des éléments et recherche un élément spécifique.

// Define the Node class for a singly linked list
class Node {
   constructor(data) {
      this.data = data;
      this.next = null;
   }
}
// Define the LinkedList class
class LinkedList {
   constructor() {
      this.head = null;
      this.size = 0;
   }
   // Add an element to the linked list
   add(element) {
      const node = new Node(element);
      // If the linked list is empty, set the new node as the head
      if (this.head === null) {
         this.head = node;
      } else {
         // Traverse to the end of the linked list and add the new node
         let current = this.head;
         while (current.next !== null) {
            current = current.next;
         }
         current.next = node;
      }
      this.size++;
   }
   // Search for an element in the linked list
   search(element) {
      let current = this.head;
      let index = 0;
      // Traverse through the linked list until the element is found
      while (current !== null) {
         if (current.data === element) {
            return `Element found at index ${index}`;
         }
         current = current.next;
         index++;
      }
      return "Element not found";
   }
}
// Create a new linked list
const ll = new LinkedList();
// Add elements to the linked list
ll.add(10);
ll.add(20);
ll.add(30);
ll.add(40);
ll.add(50);
// Search for an element in the linked list
const result = ll.search(30);
console.log(result); 
Copier après la connexion

Conclusion

La procédure de recherche d'éléments dans une liste chaînée à l'aide de JavaScript implique de créer une classe "LinkedList" qui définit des méthodes d'ajout d'éléments à la liste et de recherche d'éléments dans la liste. Le programme utilise une boucle while pour parcourir la liste chaînée et comparer l'élément de données de chaque nœud à l'élément qu'il recherche. Si l'élément est trouvé, le programme renvoie l'index du nœud, si l'élément n'est pas trouvé, le programme renvoie "Element not find".

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

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
2 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Repo: Comment relancer ses coéquipiers
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: Comment obtenir des graines géantes
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Combien de temps faut-il pour battre Split Fiction?
3 Il y a quelques semaines By DDD

Outils chauds

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

Explication détaillée de la méthode de remplacement de la chaîne JavaScript et de la FAQ Cet article explorera deux façons de remplacer les caractères de chaîne dans JavaScript: le code JavaScript interne et le HTML interne pour les pages Web. Remplacer la chaîne dans le code JavaScript Le moyen le plus direct consiste à utiliser la méthode Remplace (): str = str.replace ("trouver", "remplacer"); Cette méthode remplace uniquement la première correspondance. Pour remplacer toutes les correspondances, utilisez une expression régulière et ajoutez le drapeau global G: str = str.replace (/ fi

Tutoriel de configuration de l'API de recherche Google personnalisé Tutoriel de configuration de l'API de recherche Google personnalisé Mar 04, 2025 am 01:06 AM

Ce tutoriel vous montre comment intégrer une API de recherche Google personnalisée dans votre blog ou site Web, offrant une expérience de recherche plus raffinée que les fonctions de recherche de thème WordPress standard. C'est étonnamment facile! Vous pourrez restreindre les recherches à Y

Créez vos propres applications Web Ajax Créez vos propres applications Web Ajax Mar 09, 2025 am 12:11 AM

Vous voici donc, prêt à tout savoir sur cette chose appelée Ajax. Mais qu'est-ce que c'est exactement? Le terme Ajax fait référence à un regroupement lâche de technologies utilisées pour créer un contenu Web interactif dynamique. Le terme Ajax, inventé à l'origine par Jesse J

10 Highlighters de syntaxe jQuery 10 Highlighters de syntaxe jQuery Mar 02, 2025 am 12:32 AM

Améliorez votre présentation de code: 10 surligneurs de syntaxe pour les développeurs Partager des extraits de code sur votre site Web ou votre blog est une pratique courante pour les développeurs. Le choix du bon surligneur de syntaxe peut améliorer considérablement la lisibilité et l'attrait visuel. T

Exemple Couleurs Fichier JSON Exemple Couleurs Fichier JSON Mar 03, 2025 am 12:35 AM

Cette série d'articles a été réécrite à la mi-2017 avec des informations à jour et de nouveaux exemples. Dans cet exemple JSON, nous examinerons comment nous pouvons stocker des valeurs simples dans un fichier à l'aide du format JSON. En utilisant la notation de paire de valeurs clés, nous pouvons stocker n'importe quel type

8 Superbes plugins de mise en page JQuery Page 8 Superbes plugins de mise en page JQuery Page Mar 06, 2025 am 12:48 AM

Tirez parti de jQuery pour les dispositions de page Web sans effort: 8 plugins essentiels JQuery simplifie considérablement la mise en page de la page Web. Cet article met en évidence huit puissants plugins jQuery qui rationalisent le processus, particulièrement utile pour la création de sites Web manuels

10 tutoriels JavaScript & jQuery MVC 10 tutoriels JavaScript & jQuery MVC Mar 02, 2025 am 01:16 AM

Cet article présente une sélection organisée de plus de 10 didacticiels sur les cadres JavaScript et JQuery Model-View-Controller (MVC), parfait pour augmenter vos compétences en développement Web au cours de la nouvelle année. Ces tutoriels couvrent une gamme de sujets, de Foundatio

Qu'est-ce que & # x27; ceci & # x27; en javascript? Qu'est-ce que & # x27; ceci & # x27; en javascript? Mar 04, 2025 am 01:15 AM

Points de base Ceci dans JavaScript fait généralement référence à un objet qui "possède" la méthode, mais cela dépend de la façon dont la fonction est appelée. Lorsqu'il n'y a pas d'objet actuel, cela fait référence à l'objet global. Dans un navigateur Web, il est représenté par Window. Lorsque vous appelez une fonction, cela maintient l'objet global; mais lors de l'appel d'un constructeur d'objets ou de l'une de ses méthodes, cela fait référence à une instance de l'objet. Vous pouvez modifier le contexte de ceci en utilisant des méthodes telles que Call (), Appliquer () et Bind (). Ces méthodes appellent la fonction en utilisant la valeur et les paramètres donnés. JavaScript est un excellent langage de programmation. Il y a quelques années, cette phrase était

See all articles