zoukankan      html  css  js  c++  java
  • 并查集——A1107.Social Clusters(30)

    #include <bits/stdc++.h>
    #include <stdio.h>
    #include <stdlib.h>
    #include <queue>
    using namespace std;
    const int N = 1010;
    int father[N];
    int isRoot[N] = {0};
    int course[N] = {0};
    int findFather(int x){
        int a = x;
        while(x != father[x]){
            x = father[x];
        }
        //路径压缩
        while(a != father[a]){
            int z = a;
            a = father[a];
            father[z] = x;
        }
        return x;
    }
    void Union(int a,int b){
        int faA = findFather(a);
        int faB = findFather(b);
        if(faA != faB){
            father[faA] = faB;
        }
    }
    void init(int n){
        for(int i=1;i<=n;++i){
            father[i] = i;
            isRoot[i] = false;
        }
    }
    bool cmp(int a,int b){
        return a > b;
    }
    int main(){
        int n,k,h;
        scanf("%d",&n);
        init(n);
        for(int i=1;i<=n;++i){
            scanf("%d",&k);
            for(int j = 0;j<k;++j){
                scanf("%d",&h);
                if(course[h] == 0){
                    course[h] = i;
                }
                Union(i,findFather(course[h]));
            }
        }
        for(int i=1;i<=n;++i){
            isRoot[findFather(i)]++;
        }
        int ans = 0;
        for(int i=1;i<=n;++i){
            if(isRoot[i] != 0){
                ans++;
            }
        }
        printf("%d
    ",ans);
        sort(isRoot+1,isRoot+n+1,cmp);
        for(int i=1;i<=ans;++i){
            printf("%d",isRoot[i]);
            if(i < ans){
                printf(" ");
            }
        }
        
        system("pause");
        return 0;
    }
  • 相关阅读:
    MySQL严格模式总结
    python筛选关键字---error
    将pem证书转换成p12格式证书
    ## 游戏网关源码赏析
    pid获取
    顺序io_磁盘队列
    nsq源码阅读3_编译nsqd
    nsq源码阅读2_核心数据结构
    nsq源码阅读1_目录结构
    如何设计Mqtt的Retain?
  • 原文地址:https://www.cnblogs.com/JasonPeng1/p/12247193.html
Copyright © 2011-2022 走看看