Maison Java javaDidacticiel Comment implémenter un algorithme de tri topologique en utilisant Java

Comment implémenter un algorithme de tri topologique en utilisant Java

Sep 19, 2023 pm 01:54 PM
java accomplir Tri topologique

Comment implémenter un algorithme de tri topologique en utilisant Java

Comment utiliser Java pour implémenter un algorithme de tri topologique

Le tri topologique est un algorithme couramment utilisé en théorie des graphes, utilisé pour trier les sommets d'un graphe acyclique dirigé (DAG). Le tri topologique peut être utilisé pour résoudre des problèmes tels que les dépendances ou la planification des tâches. Dans cet article, nous présenterons comment utiliser Java pour implémenter l'algorithme de tri topologique et donnerons des exemples de code correspondants.

L'idée d'implémentation du tri topologique est la suivante :

  1. Tout d'abord, nous devons définir une structure de données d'un graphe orienté, qui peut être représentée par une liste de contiguïté. Une liste de contiguïté est une structure de données qui stocke des graphiques. Chaque sommet correspond à une liste chaînée, et la liste chaînée stocke tous les sommets adjacents au sommet.
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);
    }
}
  1. Ensuite, nous devons implémenter une méthode de tri topologique. Le processus de mise en œuvre du tri topologique peut être divisé en deux étapes :

    a. Parcourez le graphique, calculez le degré en entrée de chaque sommet (c'est-à-dire le nombre de sommets qui y pointent) et initialisez une file d'attente pour stocker les sommets avec un en degré de 0.

    b. Supprimez continuellement un sommet de la file d'attente et réduisez le degré en entrée de ses sommets adjacents. Si le degré en entrée d'un sommet devient 0, ajoutez-le à la file d'attente.

    c. Répétez l'étape (b) jusqu'à ce que la file d'attente soit vide et que le degré en entrée de tous les sommets devienne 0. Si le nombre de sommets mis en file d'attente à ce moment n'est pas égal au nombre de sommets du graphe, cela signifie qu'il y a un cycle dans le graphe et que le tri topologique ne peut pas être effectué.

import java.util.*;

class TopologicalSort {
    // 拓扑排序算法
    void topologicalSort(Graph graph) {
        int V = graph.V;
        LinkedList<Integer> adj[] = graph.adj;

        int[] indegree = new int[V];
        for (int i = 0; i < V; ++i) {
            for (int j : adj[i]) {
                indegree[j]++;
            }
        }

        Queue<Integer> queue = new LinkedList<>();
        for (int i = 0; i < V; ++i) {
            if (indegree[i] == 0) {
                queue.add(i);
            }
        }

        int count = 0;
        ArrayList<Integer> result = new ArrayList<>();

        while (!queue.isEmpty()) {
            int u = queue.poll();
            result.add(u);

            for (int v : adj[u]) {
                if (--indegree[v] == 0) {
                    queue.add(v);
                }
            }
            count++;
        }

        if (count != V) {
            System.out.println("图中存在环,无法进行拓扑排序");
            return;
        }

        System.out.println("拓扑排序结果:");
        for (int i : result) {
            System.out.print(i + " ");
        }
        System.out.println();
    }
}
  1. Enfin, nous pouvons créer un graphe et appeler la méthode de tri topologique pour le trier.
public class Main {
    public static void main(String[] args) {
        Graph graph = new Graph(6);
        graph.addEdge(5, 2);
        graph.addEdge(5, 0);
        graph.addEdge(4, 0);
        graph.addEdge(4, 1);
        graph.addEdge(2, 3);
        graph.addEdge(3, 1);

        TopologicalSort topologicalSort = new TopologicalSort();
        topologicalSort.topologicalSort(graph);
    }
}

Ci-dessus sont les étapes et les exemples de code pour implémenter l'algorithme de tri topologique en Java. Grâce à des algorithmes de tri topologique, nous pouvons résoudre efficacement des problèmes tels que les dépendances ou la planification des tâches.

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

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

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.

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

Video Face Swap

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 !

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)

Sujets chauds

Tutoriel PHP
1521
276
Correction: Ethernet 'réseau non identifié' Correction: Ethernet 'réseau non identifié' Aug 12, 2025 pm 01:53 PM

RestartyourRouterAndComputerToresolvetemporaryGlithes.2.RunthenetWorkTrouleshooTerviATheSystemTraytomAticalMatterFixComMonissues.3.RenewtheipAddressusingcomandPomptSADMinistratorByrunningIpConfig / Release, Ipconfig / Renew, NetShwinsockReset, etnetSh

Comment utiliser l'API HTTPClient en Java Comment utiliser l'API HTTPClient en Java Aug 12, 2025 pm 02:27 PM

Le cœur de l'utilisation du javahttpclientapi est de créer un httpclient, de créer un httprequest et de traiter httpResponse. 1. Utilisez httpclient.newhttpclient () ou httpclient.newbuilder () pour configurer les délais d'expiration, proxy, etc. pour créer des clients; 2. Utilisez httpRequest.newBuilder () pour définir URI, méthode, en-tête et corps pour construire des demandes; 3. Envoyez des demandes synchrones via client.send () ou envoyez des demandes asynchrones via client.sendaSync (); 4. Utilisez des handleurs.

Qu'est-ce qu'une liste liée en Java? Qu'est-ce qu'une liste liée en Java? Aug 12, 2025 pm 12:14 PM

LinkedList est une liste liée bidirectionnelle dans Java, implémentant la liste et les interfaces de Deque. Il convient aux scénarios où les éléments sont fréquemment insérés et supprimés. Surtout lorsqu'il fonctionne aux deux extrémités de la liste, il a une efficacité élevée, mais les performances d'accès aléatoire sont médiocres et la complexité du temps est O (n). L'insertion et la suppression peuvent atteindre O (1) à des endroits connus. Par conséquent, il convient à la mise en œuvre de piles, de files d'attente ou de situations où les structures doivent être modifiées dynamiquement et ne convient pas aux opérations à forte intensité de lecture qui accèdent fréquemment par index. La conclusion finale est que LinkedList est meilleur que ArrayList lorsqu'il est fréquemment modifié mais a moins d'accès.

Excel trouver et remplacer ne fonctionne pas Excel trouver et remplacer ne fonctionne pas Aug 13, 2025 pm 04:49 PM

CheckkSearchSettings like "MatchEnteRireCellContents" et "MatchCase" ByExpandingOptionsInFindanDreplace, garantissant "lookin" issettominuesand »dans" TOCORRECTSCOPE; 2.LOORHFORHIDDENCHARACTER

The Best Ides for Java Development: une revue comparative The Best Ides for Java Development: une revue comparative Aug 12, 2025 pm 02:55 PM

Thebestjavaidein2024Denpendyourndeds: 1.chooseintellijideaforprofessional, l'entreprise, le development orfulldevelopmentduetoitsSuperiorCodeIntelligence, le framewory

Comment comparer les chaînes à Java Comment comparer les chaînes à Java Aug 12, 2025 am 10:00 AM

Utilisez .equals () pour comparer le contenu de la chaîne, car == comparer uniquement les références d'objet plutôt que les caractères réels; 2. Utiliser .EqualSignoreCase () Lors de la comparaison de l'ignorance de cas; 3. Utilisez .CompareTo () lors du tri par ordre alphabétique, et .CompareToIgnoreCase () lors de l'ignorance de cas; 4. Évitez d'appeler des chaînes qui peuvent être nulles. Equals () doit être utilisé pour utiliser "littéral" .equals (variable) ou objets.equals (str1, str2) pour gérer en toute sécurité les valeurs nulles; Bref, faites toujours attention à la comparaison du contenu plutôt qu'à une référence,

Edge ne sauvant pas l'histoire Edge ne sauvant pas l'histoire Aug 12, 2025 pm 05:20 PM

Tout d'abord, Checkif "ClearbrowsingDataOnClose" IsTurneDOninsettingsandTurnitofftoenSureHistoryissaved.2.Confirmyou'renotusingInprivateMode, asitdoesNotsAvehistoryByDesigr.3.Disable ExtensionStendatoryToUleoutHeleft

Comment déployer une application Java Comment déployer une application Java Aug 17, 2025 am 12:56 AM

Préparez-vous en application par rapport à Mavenorgradletobuildajarorwarfile, externalisationConfiguration.2.ChoOSEADPLOYENDIRONMENT: Runonbaremetal / vmwithjava-jarandsystemd, deploywarontomcat, compeneriserisewithdocker, orusecloudplatformslikelise.

See all articles