zoukankan      html  css  js  c++  java
  • HDU 1827 Summer Holiday

    Summer Holiday

    Time Limit: 10000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)
    Total Submission(s): 3937    Accepted Submission(s): 1775

    Problem Description
    To see a World in a Grain of Sand 
    And a Heaven in a Wild Flower, 
    Hold Infinity in the palm of your hand 
    And Eternity in an hour. 
                      —— William Blake

    听说lcy帮大家预定了新马泰7日游,Wiskey真是高兴的夜不能寐啊,他想着得快点把这消息告诉大家,虽然他手上有所有人的联系方式,但是一个一个联系过去实在太耗时间和电话费了。他知道其他人也有一些别人的联系方式,这样他可以通知其他人,再让其他人帮忙通知一下别人。你能帮Wiskey计算出至少要通知多少人,至少得花多少电话费就能让所有人都被通知到吗?
     
    Input
    多组测试数组,以EOF结束。
    第一行两个整数N和M(1<=N<=1000, 1<=M<=2000),表示人数和联系对数。
    接下一行有N个整数,表示Wiskey联系第i个人的电话费用。
    接着有M行,每行有两个整数X,Y,表示X能联系到Y,但是不表示Y也能联系X。
     
    Output
    输出最小联系人数和最小花费。
    每个CASE输出答案一行。
     
    Sample Input
    12 16 2 2 2 2 2 2 2 2 2 2 2 2 1 3 3 2 2 1 3 4 2 4 3 5 5 4 4 6 6 4 7 4 7 12 7 8 8 7 8 9 10 9 11 10
     
    Sample Output
    3 6
     
    Author
    威士忌
     
    Source
     
    Recommend
    威士忌   |   We have carefully selected several similar problems for you:  1823 1824 1826 1822 1825 
    #include<iostream>
    #include<cstdio> 
    #include<cstring>
    #include<algorithm>
    #define MAXN 100000+15
    using namespace std;
    int n,m,tot,tim,top,sumcol,ans,bns,val[MAXN];
    int to[MAXN],from[MAXN],net[MAXN],x[MAXN],col[MAXN],into[MAXN],out[MAXN];
    int dfn[MAXN],low[MAXN],vis[MAXN],stack[MAXN],visstack[MAXN];
    inline void add(int u,int v){
        to[++tot]=v;x[tot]=u;net[tot]=from[u];from[u]=tot;
    }
    inline void tarjin(int now){
        low[now]=dfn[now]=++tim;
        stack[++top]=now;
        visstack[now]=1;
        vis[now]=1;
        for(int i=from[now];i;i=net[i])
            if(visstack[to[i]])
                low[now]=min(low[now],dfn[to[i]]);
            else if(!vis[to[i]]){
                tarjin(to[i]);
                low[now]=min(low[now],low[to[i]]);
            }
        if(dfn[now]==low[now]){
            sumcol++;
            col[now]=sumcol;
            while(stack[top]!=now){
                col[stack[top]]=sumcol;
                visstack[stack[top]]=0;
                top--;
            }
            visstack[now]=0;
            top--;
        } 
    }
    int main(){
        while(scanf("%d%d",&n,&m)!=EOF){
            top=0;tot=0;sumcol=0;tim=0;
            ans=0;bns=0;
            memset(to,0,sizeof(to));
            memset(low,0,sizeof(low));
            memset(dfn,0,sizeof(dfn));
            memset(vis,0,sizeof(vis));
            memset(col,0,sizeof(col));
            memset(net,0,sizeof(net));
            memset(out,0,sizeof(out));
            memset(into,0,sizeof(into));
            memset(from,0,sizeof(from));
            memset(stack,0,sizeof(stack));
            memset(visstack,0,sizeof(visstack));
            for(int i=1;i<=n;i++)
                scanf("%d",&val[i]);
            for(int i=1;i<=m;i++){
                int a,b;
                scanf("%d%d",&a,&b);
                add(a,b);
            }
            for(int i=1;i<=n;i++)
                if(!vis[i])    tarjin(i);
            for(int i=1;i<=m;i++)
                if(col[to[i]]!=col[x[i]]){
                    into[col[to[i]]]++;
                    out[col[x[i]]]++;
                }
            for(int i=1;i<=sumcol;i++){
                if(into[i]==0){
                    ans++;
                    int minn=0x7f7f7f7f;
                    for(int j=1;j<=n;j++)
                    if(col[j]==i)
                        minn=min(minn,val[j]);
                    bns+=minn;
                }
            }
            printf("%d %d
    ",ans,bns);
        }
    }
    细雨斜风作晓寒。淡烟疏柳媚晴滩。入淮清洛渐漫漫。 雪沫乳花浮午盏,蓼茸蒿笋试春盘。人间有味是清欢。
  • 相关阅读:
    557. Reverse Words in a String III
    14. Longest Common Prefix
    linux 修改系统时间 同步网络时间
    Django学习
    mysql操作
    mysql ,shell代码
    mysql学习
    Mac环境下mysql安装以及登录
    Mac自带Apache服务器的使用
    MongoDB连接数据库
  • 原文地址:https://www.cnblogs.com/cangT-Tlan/p/7400490.html
Copyright © 2011-2022 走看看