洛谷P2746 [USACO5.3]校园网Network of Schools
題目描述
一些學(xué)校連入一個(gè)電腦網(wǎng)絡(luò)。那些學(xué)校已訂立了協(xié)議:每個(gè)學(xué)校都會(huì)給其它的一些學(xué)校分發(fā)軟件(稱作“接受學(xué)校”)。注意即使 B 在 A 學(xué)校的分發(fā)列表中, A 也不一定在 B 學(xué)校的列表中。
你要寫(xiě)一個(gè)程序計(jì)算,根據(jù)協(xié)議,為了讓網(wǎng)絡(luò)中所有的學(xué)校都用上新軟件,必須接受新軟件副本的最少學(xué)校數(shù)目(子任務(wù) A)。更進(jìn)一步,我們想要確定通過(guò)給任意一個(gè)學(xué)校發(fā)送新軟件,這個(gè)軟件就會(huì)分發(fā)到網(wǎng)絡(luò)中的所有學(xué)校。為了完成這個(gè)任務(wù),我們可能必須擴(kuò)展接收學(xué)校列表,使其加入新成員。計(jì)算最少需要增加幾個(gè)擴(kuò)展,使得不論我們給哪個(gè)學(xué)校發(fā)送新軟件,它都會(huì)到達(dá)其余所有的學(xué)校(子任務(wù) B)。一個(gè)擴(kuò)展就是在一個(gè)學(xué)校的接收學(xué)校列表中引入一個(gè)新成員。
輸入輸出格式
輸入格式:
?
輸入文件的第一行包括一個(gè)整數(shù) N:網(wǎng)絡(luò)中的學(xué)校數(shù)目(2 <= N <= 100)。學(xué)校用前 N 個(gè)正整數(shù)標(biāo)識(shí)。
接下來(lái) N 行中每行都表示一個(gè)接收學(xué)校列表(分發(fā)列表)。第 i+1 行包括學(xué)校 i 的接收學(xué)校的標(biāo)識(shí)符。每個(gè)列表用 0 結(jié)束。空列表只用一個(gè) 0 表示。
?
輸出格式:
?
你的程序應(yīng)該在輸出文件中輸出兩行。
第一行應(yīng)該包括一個(gè)正整數(shù):子任務(wù) A 的解。
第二行應(yīng)該包括子任務(wù) B 的解。
?
輸入輸出樣例
輸入樣例#1:5 2 4 3 0 4 5 0 0 0 1 0 輸出樣例#1:
1 2
說(shuō)明
題目翻譯來(lái)自NOCOW。
USACO Training Section 5.3
?
強(qiáng)連通分量裸題。
tarjan縮點(diǎn),統(tǒng)計(jì)入度為0的點(diǎn)數(shù)即是任務(wù)A答案;入度為0的點(diǎn)數(shù)和出度為0的點(diǎn)數(shù)取max就是任務(wù)B答案。
1 /*by SilverN*/ 2 #include<algorithm> 3 #include<iostream> 4 #include<cstring> 5 #include<cstdio> 6 #include<cmath> 7 #include<vector> 8 using namespace std; 9 const int mxn=10100; 10 int read(){ 11 int x=0,f=1;char ch=getchar(); 12 while(ch<'0' || ch>'9'){if(ch=='-')f=-1;ch=getchar();} 13 while(ch>='0' && ch<='9'){x=x*10+ch-'0';ch=getchar();} 14 return x*f; 15 } 16 int n; 17 struct edge{ 18 int v,nxt; 19 }e[mxn]; 20 int hd[mxn],mct=0; 21 void add_edge(int u,int v){ 22 e[++mct].v=v;e[mct].nxt=hd[u];hd[u]=mct;return; 23 } 24 vector<int>mp[mxn]; 25 int dfn[mxn],low[mxn],dtime=0; 26 int belone[mxn],cnt=0; 27 int st[mxn],top=0; 28 bool inst[mxn]; 29 void tarjan(int u){ 30 dfn[u]=low[u]=++dtime; 31 st[++top]=u; 32 inst[u]=1; 33 for(int i=hd[u];i;i=e[i].nxt){ 34 int v=e[i].v; 35 if(!dfn[v]){ 36 tarjan(v); 37 low[u]=min(low[u],low[v]); 38 } 39 else if(inst[v]){ 40 low[u]=min(low[u],dfn[v]); 41 } 42 } 43 if(low[u]==dfn[u]){ 44 cnt++;int v=0; 45 do{ 46 v=st[top--]; 47 belone[v]=cnt; 48 inst[v]=0; 49 }while(v!=u); 50 } 51 return; 52 } 53 int ind[mxn],out[mxn]; 54 void solve(){ 55 int i,j; 56 for(i=1;i<=n;i++){ 57 for(j=hd[i];j;j=e[j].nxt){ 58 int v=e[j].v; 59 if(belone[v]!=belone[i]){ 60 mp[belone[i]].push_back(belone[v]); 61 ind[belone[v]]++; 62 out[belone[i]]++; 63 } 64 } 65 } 66 // for(i=1;i<=n;i++)printf("%d\n",belone[i]); 67 // for(i=1;i<=cnt;i++)printf("%d %d\n",ind[i],out[i]); 68 int res=0,tmp=0; 69 for(i=1;i<=cnt;i++){ 70 if(!ind[i])res++; 71 if(!out[i])tmp++; 72 } 73 printf("%d\n",res); 74 tmp=max(res,tmp);if(cnt==1)tmp=0; 75 printf("%d\n",tmp); 76 return; 77 } 78 int main(){ 79 n=read(); 80 int i,j,u,v; 81 for(i=1;i<=n;i++){ 82 u=read(); 83 while(u){ 84 add_edge(i,u); 85 u=read(); 86 } 87 } 88 for(i=1;i<=n;i++) 89 if(!dfn[i])tarjan(i); 90 solve(); 91 return 0; 92 }?
轉(zhuǎn)載于:https://www.cnblogs.com/SilverNebula/p/6073804.html
與50位技術(shù)專家面對(duì)面20年技術(shù)見(jiàn)證,附贈(zèng)技術(shù)全景圖總結(jié)
以上是生活随笔為你收集整理的洛谷P2746 [USACO5.3]校园网Network of Schools的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: Struts2.5版本之后Tomcat启
- 下一篇: swift3.0截取View生成图片 图