zoukankan      html  css  js  c++  java
  • hdu1325最大联通分量+树中点与边数值关系

    树中的点永远是边数+1。然后判断图中最大联通分量是否大于一。并且们每个点都要访问到。不过目测这道题目深搜也可以过。

    #include<iostream>
    #include<set>
    #include<cstdio>
    #include<vector>
    using namespace std;
    const int MAXN=10000005;
    const int MAXM=100005;
    
    int u[MAXN];
    int sum[MAXN];
    set<int>num;
    //bool seted[MAXN];
    int find(int p)
    {
        if(u[p]==p)
        {
           // seted[p]=1;
            return p;
        }else
        {
           // seted[p]=1;
            return u[p]=find(u[p]);
        }
    }
    void connect(int a,int b)
    {
        int f1=find(a);
        int f2=find(b);
        if(f1<f2)
        {
            u[f2]=f1;
        }else
        {
            u[f1]=f2;
        }
    }
    int main()
    {
        int n;
        while(scanf("%d",&n)!=EOF)
        {
            int max=1;
            int i=0;
            num.clear();
            vector<int>input[2];
            input[0].clear();
            input[1].clear();
            //memset(seted,0,sizeof(seted));
            for(i=0;i<=n-1;i++)
            {
                int num1,num2;
                scanf("%d%d",&num1,&num2);
                
                num.insert(num1);
                num.insert(num2);
                input[0].push_back(num1);
                input[1].push_back(num2);
            }
            set<int>::reverse_iterator cp=num.rbegin();
            for(cp=num.rbegin();cp!=num.rend();cp++)
            {
                u[*cp]=*cp;
                sum[*cp]=0;
            }
            //memset(sum,0,sizeof(sum));
            for(i=0;i<=n-1;i++)
            {
                connect(input[0][i],input[1][i]);
            }
            for(cp=num.rbegin();cp!=num.rend();cp++)
            {
                sum[find(*cp)]++;
            }
            for(cp=num.rbegin();cp!=num.rend();cp++)
            {
                if(sum[*cp]>max)
                {
                    max=sum[*cp];
                }
            }
            printf("%d\n",max);
        }
        return 0;
    }
    

      

  • 相关阅读:
    dede图片横向滚动
    dede各种运用[转]
    PROFIBUS-DP现场总线的结构及应用
    51单片机的中断优先级及中断嵌套
    WPF里面制作圆角文本框
    【转】什么叫51单片机最小系统
    【转】(C#)OPC客户端源码
    路漫漫其修远兮,吾要上下左右前后而求索
    二叉树创建为什么用二级指针
    无向图的邻接表创建
  • 原文地址:https://www.cnblogs.com/cj695/p/2609622.html
Copyright © 2011-2022 走看看