Maison développement back-end Tutoriel Python Comment implémenter un algorithme de recherche en largeur à l'aide de Python ?

Comment implémenter un algorithme de recherche en largeur à l'aide de Python ?

Sep 19, 2023 am 08:51 AM
python 算法 première recherche en largeur

Comment implémenter un algorithme de recherche en largeur à laide de Python ?

Comment implémenter un algorithme de recherche en largeur à l'aide de Python ?

Breadth-First Search (BFS) est un algorithme de recherche de graphiques de base utilisé pour trouver le chemin le plus court vers un nœud (ou un état) spécifique dans un graphique ou un arbre. Il peut être largement utilisé dans de nombreux domaines, comme trouver la chaîne de relations amicales la plus courte sur les réseaux sociaux, résoudre des problèmes de labyrinthe, etc. Python fournit des structures de données et des bibliothèques de fonctions puissantes, ce qui rend la mise en œuvre de BFS une tâche relativement simple. Cet article explique comment utiliser Python pour implémenter l'algorithme BFS et fournit des exemples de code spécifiques.

Tout d'abord, nous devons définir une structure de données graphique. Les graphiques peuvent être représentés à l'aide de listes de contiguïté ou de matrices de contiguïté. Dans cet article, nous représenterons des graphiques à l'aide de listes de contiguïté. Voici la définition de la structure de données du graphe :

class Graph:
    def __init__(self, vertices):
        self.V = vertices
        self.adj = [[] for _ in range(vertices)]
    
    def add_edge(self, src, dest):
        self.adj[src].append(dest)
Copier après la connexion

Le code ci-dessus définit une classe Graph, qui contient un constructeur et deux méthodes : add_edge()用于添加边,__init__() est utilisé pour initialiser la classe.

Ensuite, nous pouvons implémenter l'algorithme BFS. L'idée de base de l'algorithme BFS est de partir d'un nœud de départ donné et de parcourir les nœuds du graphique couche par couche jusqu'à ce que le nœud cible soit trouvé. Pendant le processus de parcours, une file d'attente est utilisée pour stocker les nœuds à visiter. Voici le code pour implémenter l'algorithme BFS à l'aide de Python :

from collections import deque

def BFS(graph, start, goal):
    visited = [False] * graph.V
    queue = deque()

    queue.append(start)
    visited[start] = True

    while queue:
        node = queue.popleft()
        print(node, end=" ")

        if node == goal:
            print("目标节点已找到")
            break

        for i in graph.adj[node]:
            if not visited[i]:
                queue.append(i)
                visited[i] = True

    if not queue:
        print("目标节点未找到")
Copier après la connexion

Le code ci-dessus définit une fonction appelée BFS. Cette fonction accepte trois paramètres : le graphique de l'objet graphique, le début du nœud de départ et l'objectif du nœud cible. L'algorithme utilise une liste visitée pour enregistrer les nœuds visités et une file d'attente pour stocker les nœuds à visiter. Dans chaque boucle, le premier élément de la file d'attente est supprimé, le nœud est visité et ses nœuds voisins non visités sont ajoutés à la file d'attente. Bouclez jusqu'à ce que le nœud cible soit trouvé ou que la file d'attente soit vide.

Enfin, nous pouvons utiliser le graphe défini ci-dessus et l'algorithme BFS pour une application pratique. Voici un exemple :

g = Graph(6)
g.add_edge(0, 1)
g.add_edge(0, 2)
g.add_edge(1, 3)
g.add_edge(1, 4)
g.add_edge(2, 4)
g.add_edge(3, 4)
g.add_edge(3, 5)
g.add_edge(4, 5)

print("BFS遍历结果为:")
BFS(g, 0, 5)
Copier après la connexion

Le code ci-dessus crée d'abord un objet graphique g contenant 6 nœuds, et ajoute plusieurs arêtes. Appelez ensuite la fonction BFS pour rechercher le chemin du nœud 0 au nœud 5. Le programme affichera les résultats du parcours BFS.

En résumé, cet article présente comment utiliser Python pour implémenter l'algorithme de recherche en largeur et fournit des exemples de code spécifiques. Grâce à la puissante structure de données et à la bibliothèque de fonctions de Python, nous pouvons facilement implémenter l'algorithme BFS et l'appliquer à divers scénarios pratiques.

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)
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Comment réparer l'audio si vous n'entendez personne
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Comment déverrouiller tout dans Myrise
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌

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)

Quelle est la raison pour laquelle PS continue de montrer le chargement? Quelle est la raison pour laquelle PS continue de montrer le chargement? Apr 06, 2025 pm 06:39 PM

Les problèmes de «chargement» PS sont causés par des problèmes d'accès aux ressources ou de traitement: la vitesse de lecture du disque dur est lente ou mauvaise: utilisez Crystaldiskinfo pour vérifier la santé du disque dur et remplacer le disque dur problématique. Mémoire insuffisante: améliorez la mémoire pour répondre aux besoins de PS pour les images à haute résolution et le traitement complexe de couche. Les pilotes de la carte graphique sont obsolètes ou corrompues: mettez à jour les pilotes pour optimiser la communication entre le PS et la carte graphique. Les chemins de fichier sont trop longs ou les noms de fichiers ont des caractères spéciaux: utilisez des chemins courts et évitez les caractères spéciaux. Problème du PS: réinstaller ou réparer le programme d'installation PS.

Comment accélérer la vitesse de chargement de PS? Comment accélérer la vitesse de chargement de PS? Apr 06, 2025 pm 06:27 PM

La résolution du problème du démarrage lent Photoshop nécessite une approche à plusieurs volets, notamment: la mise à niveau du matériel (mémoire, lecteur à semi-conducteurs, CPU); des plug-ins désinstallés ou incompatibles; nettoyer régulièrement les déchets du système et des programmes de fond excessifs; clôture des programmes non pertinents avec prudence; Éviter d'ouvrir un grand nombre de fichiers pendant le démarrage.

Comment résoudre le problème du chargement lorsque PS est démarré? Comment résoudre le problème du chargement lorsque PS est démarré? Apr 06, 2025 pm 06:36 PM

Un PS est coincé sur le "chargement" lors du démarrage peut être causé par diverses raisons: désactiver les plugins corrompus ou conflictuels. Supprimer ou renommer un fichier de configuration corrompu. Fermez des programmes inutiles ou améliorez la mémoire pour éviter une mémoire insuffisante. Passez à un entraînement à semi-conducteurs pour accélérer la lecture du disque dur. Réinstaller PS pour réparer les fichiers système corrompus ou les problèmes de package d'installation. Afficher les informations d'erreur pendant le processus de démarrage de l'analyse du journal d'erreur.

Fonction de page suivante HTML Fonction de page suivante HTML Apr 06, 2025 am 11:45 AM

<p> La fonction de page suivante peut être créée via HTML. Les étapes incluent: la création d'éléments de conteneur, la division du contenu, l'ajout de liens de navigation, la cachette d'autres pages et l'ajout de scripts. Cette fonctionnalité permet aux utilisateurs de parcourir du contenu segmenté, affichant une seule page à la fois et convient pour afficher de grandes quantités de données ou de contenu. </p>

Comment résoudre le problème du chargement lorsque le PS ouvre le fichier? Comment résoudre le problème du chargement lorsque le PS ouvre le fichier? Apr 06, 2025 pm 06:33 PM

Le bégaiement "Chargement" se produit lors de l'ouverture d'un fichier sur PS. Les raisons peuvent inclure: un fichier trop grand ou corrompu, une mémoire insuffisante, une vitesse du disque dur lente, des problèmes de pilote de carte graphique, des conflits de version PS ou du plug-in. Les solutions sont: vérifier la taille et l'intégrité du fichier, augmenter la mémoire, mettre à niveau le disque dur, mettre à jour le pilote de carte graphique, désinstaller ou désactiver les plug-ins suspects et réinstaller PS. Ce problème peut être résolu efficacement en vérifiant progressivement et en faisant bon usage des paramètres de performances PS et en développant de bonnes habitudes de gestion des fichiers.

Le chargement lent PS est-il lié à la configuration de l'ordinateur? Le chargement lent PS est-il lié à la configuration de l'ordinateur? Apr 06, 2025 pm 06:24 PM

La raison du chargement lent PS est l'impact combiné du matériel (CPU, mémoire, disque dur, carte graphique) et logiciel (système, programme d'arrière-plan). Les solutions incluent: la mise à niveau du matériel (en particulier le remplacement des disques à semi-conducteurs), l'optimisation des logiciels (nettoyage des ordures système, mise à jour des pilotes, vérification des paramètres PS) et traitement des fichiers PS. La maintenance ordinaire de l'ordinateur peut également aider à améliorer la vitesse d'exécution du PS.

Comment résoudre le problème du chargement lorsque PS montre toujours qu'il se charge? Comment résoudre le problème du chargement lorsque PS montre toujours qu'il se charge? Apr 06, 2025 pm 06:30 PM

La carte PS est "Chargement"? Les solutions comprennent: la vérification de la configuration de l'ordinateur (mémoire, disque dur, processeur), nettoyage de la fragmentation du disque dur, mise à jour du pilote de carte graphique, ajustement des paramètres PS, réinstaller PS et développer de bonnes habitudes de programmation.

Les exportations PDF peuvent-elles être exportées par lots par PS? Les exportations PDF peuvent-elles être exportées par lots par PS? Apr 06, 2025 pm 04:54 PM

Il existe trois façons d'exporter des PDF par lots sur PS: utilisez les fonctions d'action PS: enregistrer et ouvrir les fichiers et exporter des actions PDF, et exécuter des actions dans une boucle. À l'aide d'un logiciel tiers: utilisez des logiciels de gestion de fichiers ou des outils d'automatisation pour spécifier les dossiers d'entrée et de sortie et définir le format de nom de fichier. Utilisez des scripts: écrivez des scripts pour personnaliser la logique d'exportation par lots, mais des connaissances en programmation sont nécessaires.

See all articles