日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

nyoj--120--校园网络(scc+缩点)

發(fā)布時(shí)間:2023/12/10 编程问答 41 豆豆
生活随笔 收集整理的這篇文章主要介紹了 nyoj--120--校园网络(scc+缩点) 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

校園網(wǎng)絡(luò)

時(shí)間限制:3000?ms ?|? 內(nèi)存限制:65535?KB 難度:5 描述

南陽理工學(xué)院共有M個(gè)系,分別編號(hào)1~M,其中各個(gè)系之間達(dá)成有一定的協(xié)議,如果某系有新軟件可用時(shí),該系將允許一些其它的系復(fù)制并使用該軟件。但該允許關(guān)系是單向的,即:A系允許B系使用A的軟件時(shí),B未必一定允許A使用B的軟件。

現(xiàn)在,請(qǐng)你寫一個(gè)程序,根據(jù)各個(gè)系之間達(dá)成的協(xié)議情況,計(jì)算出最少需要添加多少個(gè)兩系之間的這種允許關(guān)系,才能使任何一個(gè)系有軟件使用的時(shí)候,其它所有系也都有軟件可用。

輸入
第一行輸入一個(gè)整數(shù)T,表示測(cè)試數(shù)據(jù)的組數(shù)(T<10)
每組測(cè)試數(shù)據(jù)的第一行是一個(gè)整數(shù)M,表示共有M個(gè)系(2<=M<=100)。
隨后的M行,每行都有一些整數(shù),其中的第i行表示系i允許這幾個(gè)系復(fù)制并使用系i的軟件。每行結(jié)尾都是一個(gè)0,表示本行輸入結(jié)束。如果某個(gè)系不允許其它任何系使用該系軟件,則本行只有一個(gè)0.
輸出
對(duì)于每組測(cè)試數(shù)據(jù),輸出最少需要添加的這種允許關(guān)系的個(gè)數(shù)。
樣例輸入
1 5 2 4 3 0 4 5 0 0 0 1 0
樣例輸出
2
來源
POJ改編
上傳者

張?jiān)坡?/p>


<pre name="code" class="cpp">#include<stdio.h> #include<string.h> #include<queue> #include<stack> #include<vector> #include<algorithm> using namespace std; #define MAXN 50010 int in[MAXN],out[MAXN],sumin,sumout; vector<int>G[MAXN]; vector<int>scc[MAXN]; struct node {int u,v;int next; }edge[MAXN]; int head[MAXN],cnt,scc_cnt,dfs_clock; int sccno[MAXN],low[MAXN],dfn[MAXN]; bool Instack[MAXN]; int n; stack<int>s; void init() {memset(head,-1,sizeof(head));cnt=0; } void add(int u,int v) {node E={u,v,head[u]};edge[cnt]=E;head[u]=cnt++; } void getmap() {for(int i=1,a;i<=n;i++){while(scanf("%d",&a),a)add(i,a);} } void suodian() {for(int i=1;i<=scc_cnt;i++)G[i].clear(),in[i]=0,out[i]=0;for(int i=0;i<n;i++){int u=sccno[edge[i].u];int v=sccno[edge[i].v];if(u!=v)out[u]++,in[v]++;} } void tarjan(int u,int fa) {int v;low[u]=dfn[u]=++dfs_clock;s.push(u);Instack[u]=true;for(int i=head[u];i!=-1;i=edge[i].next){v=edge[i].v;if(!dfn[v]){tarjan(v,u);low[u]=min(low[u],low[v]);}else if(Instack[v])low[u]=min(low[u],dfn[v]);}if(dfn[u]==low[u]){scc_cnt++;scc[scc_cnt].clear();for(;;){v=s.top();s.pop();Instack[v]=false;sccno[v]=scc_cnt;scc[scc_cnt].push_back(v);if(u==v) break;}} } void solve() {sumin=sumout=0;if(scc_cnt==1)printf("0\n");else{for(int i=1;i<=scc_cnt;i++){if(in[i]==0) sumin++;if(out[i]==0) sumout++;}int sum=max(sumin,sumout);printf("%d\n",sum);} } void find(int l,int r) {memset(Instack,false,sizeof(Instack));memset(low,0,sizeof(low));memset(dfn,0,sizeof(dfn));memset(sccno,0,sizeof(sccno));dfs_clock=scc_cnt=0;for(int i=l;i<=r;i++)if(!dfn[i])tarjan(i,-1); } int main() {int t;scanf("%d",&t);while(t--){init();scanf("%d",&n);getmap();find(1,n);suodian();solve();} }

轉(zhuǎn)載于:https://www.cnblogs.com/playboy307/p/5273529.html

總結(jié)

以上是生活随笔為你收集整理的nyoj--120--校园网络(scc+缩点)的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。