hdu3836之強聯通縮點

來源:互聯網
上載者:User

標籤:des   style   blog   class   code   java   

Summer Holiday Time Limit: 10000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)
Total Submission(s): 1430    Accepted Submission(s): 645


Problem DescriptionTo 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 162 2 2 2 2 2 2 2 2 2 2 2 1 33 22 13 42 43 55 44 66 47 47 127 88 78 910 911 10
 
Sample Output
3 6
#include <iostream>#include <cstdio>#include <cstdlib>#include <cstring>#include <string>#include <queue>#include <algorithm>#include <map>#include <cmath>#include <iomanip>#define INF 99999999typedef long long LL;using namespace std;const int MAX=1000+10;int n,m,size,top,index;int head[MAX],val[MAX],dfn[MAX],low[MAX];int mark[MAX],stack[MAX];struct Edge{int v,next;Edge(){}Edge(int V,int NEXT):v(V),next(NEXT){}}edge[MAX*2];void Init(int num){for(int i=0;i<=num;++i)head[i]=-1,mark[i]=0;size=top=index=0;}void InsertEdge(int u,int v){edge[size]=Edge(v,head[u]);head[u]=size++;}void tarjan(int u){if(mark[u])return;dfn[u]=low[u]=++index;stack[++top]=u;mark[u]=1;for(int i=head[u];i != -1;i=edge[i].next){int v=edge[i].v;tarjan(v);if(mark[v] == 1)low[u]=min(low[u],low[v]);}if(dfn[u] == low[u]){while(stack[top] != u){mark[stack[top]]=-1;val[u]=min(val[u],val[stack[top]]);low[stack[top--]]=low[u];}mark[u]=-1;--top;}}int main(){int u,v;while(~scanf("%d%d",&n,&m)){Init(n);for(int i=1;i<=n;++i)scanf("%d",val+i);for(int i=0;i<m;++i){scanf("%d%d",&u,&v);InsertEdge(u,v); }for(int i=1;i<=n;++i){if(mark[i])continue;tarjan(i);}for(int i=0;i<=n;++i)mark[i]=0;for(int i=1;i<=n;++i){for(int j=head[i];j != -1;j=edge[j].next){v=edge[j].v;if(low[i] == low[v])continue;mark[low[v]]=1;}}int sum=0,ans=0;for(int i=1;i<=n;++i){if(!mark[low[i]] && dfn[i] == low[i])++ans,sum+=val[i];mark[low[i]]=1;}printf("%d %d\n",ans,sum);}return 0;}



相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.