首页 > 代码库 > 【dfs】BZOJ1703-[Usaco2007 Mar]Ranking the Cows 奶牛排名

【dfs】BZOJ1703-[Usaco2007 Mar]Ranking the Cows 奶牛排名

【题目大意】

农夫约翰有N(1≤N≤1000)头奶牛,每一头奶牛都有一个确定的独一无二的正整数产奶率.约翰想要让这些奶牛按产奶率从高到低排序,约翰已经比较了M(1≤M≤10000)对奶牛的产奶率,但他发现,他还需要再做一张关于另外C对奶牛的产奶率比较,才能推断出所有奶牛的产奶率排序。请帮他确定C的最小值。

【思路】

对于M对关系,从产奶率高的往产奶率低的连一条有向边。对于每个节点i,它能抵达的节点的总数即是能比较得出的比它小的奶牛总数。

由于原本总共有N*(N-1)/2对关系,ans=N*(N-1)/2-Σ从该头奶牛能抵达的节点总数。

 1 #include<bits/stdc++.h>
 2 using namespace std;
 3 const int MAXN=1000+5;
 4 int n,m,ans,tmp;
 5 int vis[MAXN];
 6 vector<int> E[MAXN];
 7 
 8 void dfs(int u,int T)
 9 {
10     for (int i=0;i<E[u].size();i++)
11     {
12         int v=E[u][i];
13         if (vis[v]!=T)
14         {
15             tmp++;
16             vis[v]=T;
17             dfs(v,T);
18         }
19     }
20 }
21 
22 void init()
23 {
24     scanf("%d%d",&n,&m);
25     for (int i=1;i<=m;i++)
26     {
27         int u,v;
28         scanf("%d%d",&u,&v);
29         E[u].push_back(v);
30     }
31 }
32 
33 void solve()
34 {
35     ans=0;
36     memset(vis,0,sizeof(vis));
37     for (int i=1;i<=n;i++)
38     {
39         tmp=0;
40         dfs(i,i);
41         ans+=tmp;
42     }
43     ans=(n-1)*n/2-ans;
44     printf("%d\n",ans);
45 }
46 
47 int main()
48 {
49     init();
50     solve();
51     return 0;
52 } 

 

【dfs】BZOJ1703-[Usaco2007 Mar]Ranking the Cows 奶牛排名