"Si un ouvrier veut bien faire son travail, il doit d'abord affûter ses outils." - Confucius, "Les Entretiens de Confucius. Lu Linggong"
Page de garde > La programmation > Apprentissage de graphes d’ensembles disjoints

Apprentissage de graphes d’ensembles disjoints

Publié le 2024-09-01
Parcourir:775

Disjoint Set Graph Learning

L'ensemble disjoint est une structure de données utilisée dans l'arbre couvrant minimal de Kruskal.
Ces structures de données nous permettent de créer l'union de deux ou plusieurs nœuds.
Cela nous permet de déterminer si deux nœuds appartiennent au même composant du graphe de not.
La complexité temporelle est O(4alpha) (si nous utilisons la compression de chemin, ce que nous faisons, sinon elle sera logarithmique), ce qui est une complexité temporelle constante qui a été prouvée.

Pour plus d'informations, reportez-vous à

class Main{
    int parent[]  = new int[100000];
    int rank[] = new int[100000];
    void makeSet(){
        for(int i=1;i6->4->3 , here 3 is the parent of this union, so in order to get the parent of 7 which is 3 we can path compress it. like 7->3,6->3,4->3 etc.
    }
    void union(int u, int v){
        u = findParent(u);
        v = findParent(v);
        if(rank[u]  rank[v]) parent[v] = u;
        else parent[u] =v; // or parent[v] = u;
        // here u and v had the same rank
        //and now v became parent of u hence its rank will increase
        rank[v]  ;
    }

    public static void main(String args[]) throws Exception{
        Main m = new Main();
        //if we where given no of nodes as n
        BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
        int n = Integer.parseInt(br.readLine());
        while(n>0){
            int u = n--;
            int v = n--;
            m.union(u,v);// this will create union of n nodes
        }
        // if 2 and 3 belong to the same component or not find out
        if(findParent(2)! = findParent(3)) System.out.println("Different component");
        else System.out.println("Same component");
    }
}
Déclaration de sortie Cet article est reproduit sur : https://dev.to/prashantrmishra/disjoint-set-graph-learning-1f4n?1 En cas de violation, veuillez contacter [email protected] pour le supprimer.
Dernier tutoriel Plus>

Clause de non-responsabilité: Toutes les ressources fournies proviennent en partie d'Internet. En cas de violation de vos droits d'auteur ou d'autres droits et intérêts, veuillez expliquer les raisons détaillées et fournir une preuve du droit d'auteur ou des droits et intérêts, puis l'envoyer à l'adresse e-mail : [email protected]. Nous nous en occuperons pour vous dans les plus brefs délais.

Copyright© 2022 湘ICP备2022001581号-3