


Comment implémenter un algorithme de recherche en profondeur en utilisant Java
Comment implémenter un algorithme de recherche en profondeur en utilisant Java
深度优先搜索 (DFS) 是图论中一种经典的搜索算法,它通常用于解决图或树的遍历问题。本文将介绍如何使用Java编写深度优先搜索算法,并提供具体的代码示例。
- 算法原理
深度优先搜索 (DFS) 从一个节点开始,沿着一条路径一直往下走,直到不能再走为止,然后回退到上一个节点,尝试另一条路径。这种搜索方式类似于迷宫中的探索,我们首先选择一个节点作为起始点,标记为已访问,然后递归地访问其相邻节点,直到达到终点或者所有节点都已访问。
- 实现步骤
步骤一:创建一个图类,用于表示图的结构。我们可以使用邻接表或邻接矩阵来表示图。
class Graph { private int V; // 图的顶点数 private LinkedList<Integer> adj[]; // 邻接表 // 构造方法 Graph(int v) { V = v; adj = new LinkedList[v]; for(int i=0; i<v; ++i) { adj[i] = new LinkedList(); } } // 添加边 void addEdge(int v, int w) { adj[v].add(w); } // 深度优先搜索 void DFS(int v, boolean visited[]) { visited[v] = true; // 标记当前节点为已访问 System.out.print(v + " "); // 打印当前节点 Iterator<Integer> i = adj[v].listIterator(); while(i.hasNext()) { int n = i.next(); if(!visited[n]) { DFS(n, visited); } } } // 对图进行深度优先搜索 void depthFirstSearch(int v) { boolean visited[] = new boolean[V]; // 用于记录节点是否已经访问过 DFS(v, visited); } }
步骤二:创建一个测试类,用于验证深度优先搜索算法的正确性。
class DFSAlgorithm { public static void main(String args[]) { Graph graph = new Graph(5); // 创建一个包含5个顶点的图 graph.addEdge(0, 1); graph.addEdge(0, 2); graph.addEdge(1, 3); graph.addEdge(2, 4); System.out.println("深度优先搜索结果:"); graph.depthFirstSearch(0); } }
- 运行结果
深度优先搜索结果:
0 1 3 2 4
- 总结
深度优先搜索算法是一种常用的图算法,它能够遍历图中的所有节点。通过递归的方式,我们可以简单地实现深度优先搜索算法。以上代码提供了一个基本的深度优先搜索算法的示例,你可以根据实际需求进行修改和扩展。
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!

Outils d'IA chauds

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

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

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

Video Face Swap
Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

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

Sujets chauds

Guide du nombre parfait en Java. Nous discutons ici de la définition, comment vérifier le nombre parfait en Java ?, des exemples d'implémentation de code.

Guide de Weka en Java. Nous discutons ici de l'introduction, de la façon d'utiliser Weka Java, du type de plate-forme et des avantages avec des exemples.

Guide du nombre de Smith en Java. Nous discutons ici de la définition, comment vérifier le numéro Smith en Java ? exemple avec implémentation de code.

Dans cet article, nous avons conservé les questions d'entretien Java Spring les plus posées avec leurs réponses détaillées. Pour que vous puissiez réussir l'interview.

Java 8 présente l'API Stream, fournissant un moyen puissant et expressif de traiter les collections de données. Cependant, une question courante lors de l'utilisation du flux est: comment se casser ou revenir d'une opération FOREAK? Les boucles traditionnelles permettent une interruption ou un retour précoce, mais la méthode Foreach de Stream ne prend pas directement en charge cette méthode. Cet article expliquera les raisons et explorera des méthodes alternatives pour la mise en œuvre de terminaison prématurée dans les systèmes de traitement de flux. Lire plus approfondie: Améliorations de l'API Java Stream Comprendre le flux Forach La méthode foreach est une opération terminale qui effectue une opération sur chaque élément du flux. Son intention de conception est

Guide de TimeStamp to Date en Java. Ici, nous discutons également de l'introduction et de la façon de convertir l'horodatage en date en Java avec des exemples.

Les capsules sont des figures géométriques tridimensionnelles, composées d'un cylindre et d'un hémisphère aux deux extrémités. Le volume de la capsule peut être calculé en ajoutant le volume du cylindre et le volume de l'hémisphère aux deux extrémités. Ce tutoriel discutera de la façon de calculer le volume d'une capsule donnée en Java en utilisant différentes méthodes. Formule de volume de capsule La formule du volume de la capsule est la suivante: Volume de capsule = volume cylindrique volume de deux hémisphères volume dans, R: Le rayon de l'hémisphère. H: La hauteur du cylindre (à l'exclusion de l'hémisphère). Exemple 1 entrer Rayon = 5 unités Hauteur = 10 unités Sortir Volume = 1570,8 unités cubes expliquer Calculer le volume à l'aide de la formule: Volume = π × r2 × h (4

PHP et Python ont chacun leurs propres avantages, et le choix doit être basé sur les exigences du projet. 1.Php convient au développement Web, avec une syntaxe simple et une efficacité d'exécution élevée. 2. Python convient à la science des données et à l'apprentissage automatique, avec une syntaxe concise et des bibliothèques riches.
