id=2186">【2186】Popular Cows(强联通分支及其缩点)

Popular Cows
Time Limit: 2000MS   Memory Limit: 65536K
Total Submissions: 28323   Accepted: 11459

Description

Every cow's dream is to become the most popular cow in the herd. In a herd of N (1 <= N <= 10,000) cows, you are given up to M (1 <= M <= 50,000) ordered pairs of the form (A, B) that tell you that cow A thinks that cow B is popular.
Since popularity is transitive, if A thinks B is popular and B thinks C is popular, then A will also think that C is


popular, even if this is not explicitly specified by an ordered pair in the input. Your task is to compute the number of cows that are considered popular by every other cow.

Input

* Line 1: Two space-separated integers, N and M



* Lines 2..1+M: Two space-separated numbers A and B, meaning that A thinks B is popular.

Output

* Line 1: A single integer that is the number of cows who are considered popular by every other cow.

Sample Input

3 3
1 2
2 1
2 3

Sample Output

1

Hint

Cow 3 is the only cow of high popularity.

Source

题目大意是有n头牛,他们有m对特殊的关系

关系A B表示A敬仰B 恩 是感觉怪怪的= =

然后假设A敬仰B B敬仰C 那么A也敬仰C 也就是关系是可传递的

要求找出被其它牛都敬仰的牛的数目

一開始非常费解。要不是放在强连通里,实在没法往这方向靠……

事实上反过来想的话比較好像,强连通分支的定义——强连通分支中从不论什么一个点都能够訪问到其余各点(有向图)

这样再回到题中 能够得出两个结论

1.假设某个强联通分支中的某仅仅牛被分支外的全部牛都敬仰,也就是说分支外的牛都有一条通向他的路,和他在同一个强连通分支里的全部牛也是满足要求的。

2.假设分支中有某头牛敬仰分支外的牛。那么就不存在被全部牛都敬仰的牛。(能够换种方式来想,假设分支中某头牛敬仰分支外的牛,还被其余牛都敬仰,那么分支外的这头牛也应该被包括在分支内。由于这样就说明分支外的那头牛。会有一条通向分支内的路径,也就是符合强连通分量的定义)

3.经2结论可知,出度为0的强连通分支。就是满足条件的牛群。

但假设有两群。就不存在这样的牛。由于两个分支间是没有关系的。

能够自己画一画看看。

找到方法推断就好办了,首先把全部的强连通分支求出来,缩点后变成一团团的。找出出度为0的缩点。假设存在两个或两个以上,答案就是0。假设之存在一个,那么这个点中的全部牛都是满足题意的牛,统计输出就可以。

代码例如以下:

#include <iostream>
#include <cmath>
#include <vector>
#include <cstdlib>
#include <cstdio>
#include <cstring>
#include <queue>
#include <list>
#include <algorithm>
#include <map>
#include <set>
#include <stack>
#define LL long long
#define fread() freopen("in.in","r",stdin)
#define fwrite() freopen("out.out","w",stdout) using namespace std;
const int INF = 0x3f3f3f3f;
const int msz = 10000;
const double eps = 1e-8; struct Edge
{
int v,next;
}; Edge eg[50050];
int head[10010];
int vis[10010];
//dfs序
int dfn[10010];
//最早可訪问到的点
int low[10010];
//缩点的出度
int in[10010];
//缩点是否满足出度为0
bool can[10010];
//缩点的根
int pre[10010];
int n,tp,tm;
stack <int> s; void tarjan(int u)
{
s.push(u);
vis[u] = 1;
low[u] = dfn[u] = tm++;
int v; for(int i = head[u]; i != -1; i = eg[i].next)
{
v = eg[i].v;
//点未被訪问过
if(vis[v] == 0)
{
tarjan(v);
vis[v] = 1;
low[u] = min(low[u],low[v]);
}
//点在栈中
else if(vis[v] == 1)
{
low[u] = min(low[u],dfn[v]);
}
} //此点为树根
if(low[u] == dfn[u])
{
int x = s.top();
while(x != u)
{
pre[x] = u;
s.pop();
x = s.top();
}
//标记该分支中各点树根为u
pre[x] = u;
s.pop();
}
} int main()
{
int u,v;
while(~scanf("%d%d",&n,&tp))
{
memset(head,-1,sizeof(head)); for(int i = 0; i < tp; ++i)
{
scanf("%d%d",&u,&v);
eg[i].v = v;
eg[i].next = head[u];
head[u] = i;
} memset(vis,0,sizeof(vis)); for(int i = 1; i <= n; ++i)
{
if(vis[i]) continue; tm = 0;
tarjan(i);
} memset(in,0,sizeof(in));
memset(can,0,sizeof(can));
int f = 0;
for(int i = 1; i <= n; ++i)
{
for(int j = head[i]; j != -1; j = eg[j].next)
{
v = eg[j].v;
//两个点不在同一个分支内
if(pre[v] != pre[i])
{
in[i]++;
}
}
//该点出度不为0
if(in[i])
{
//该缩点出度不为0
can[pre[i]] = 1;
}
} int cnt = 0;
for(int i = 1; i <= n; ++i)
{
//该点为分支根,同一时候该分支出度为0
if(pre[i] == i && can[i] == 0)
{
f = i;
cnt++;
}
if(cnt > 1) break;
} //出度为0的分支多余1个
if(cnt != 1)
{
puts("0");
}
else
{
cnt = 0;
//统计分支中的点数
for(int i = 1; i <= n; ++i)
{
if(pre[i] == f) cnt++;
}
printf("%d\n",cnt);
}
} return 0;
}

【2186】Popular Cows(强连通分支及其缩点)的更多相关文章

  1. poj 2186 Popular Cows (强连通分量+缩点)

    http://poj.org/problem?id=2186 Popular Cows Time Limit: 2000MS   Memory Limit: 65536K Total Submissi ...

  2. POJ 2186 Popular Cows(Targin缩点)

    传送门 Popular Cows Time Limit: 2000MS   Memory Limit: 65536K Total Submissions: 31808   Accepted: 1292 ...

  3. POJ 2186 Popular Cows(强连通分量缩点)

    题目链接:http://poj.org/problem?id=2186 题目意思大概是:给定N(N<=10000)个点和M(M<=50000)条有向边,求有多少个“受欢迎的点”.所谓的“受 ...

  4. POJ 2186 Popular Cows (强联通)

    id=2186">http://poj.org/problem? id=2186 Popular Cows Time Limit: 2000MS   Memory Limit: 655 ...

  5. 强连通分量分解 Kosaraju算法 (poj 2186 Popular Cows)

    poj 2186 Popular Cows 题意: 有N头牛, 给出M对关系, 如(1,2)代表1欢迎2, 关系是单向的且能够传递, 即1欢迎2不代表2欢迎1, 可是假设2也欢迎3那么1也欢迎3. 求 ...

  6. poj 2186 Popular Cows 【强连通分量Tarjan算法 + 树问题】

    题目地址:http://poj.org/problem?id=2186 Popular Cows Time Limit: 2000MS   Memory Limit: 65536K Total Sub ...

  7. tarjan缩点练习 洛谷P3387 【模板】缩点+poj 2186 Popular Cows

    缩点练习 洛谷 P3387 [模板]缩点 缩点 解题思路: 都说是模板了...先缩点把有环图转换成DAG 然后拓扑排序即可 #include <bits/stdc++.h> using n ...

  8. poj 2186 Popular Cows【tarjan求scc个数&&缩点】【求一个图中可以到达其余所有任意点的点的个数】

    Popular Cows Time Limit: 2000MS   Memory Limit: 65536K Total Submissions: 27698   Accepted: 11148 De ...

  9. poj 2186 Popular Cows

    Popular Cows Time Limit: 2000MS   Memory Limit: 65536K Total Submissions: 29908   Accepted: 12131 De ...

  10. POJ-2186 Popular Cows,tarjan缩点找出度为0的点。

    Popular Cows 题意:一只牛崇拜另外一只牛,这种崇拜关系可以传导.A->B,B->C =>A->C.现在给出所有的关系问你有多少牛被其他所有的牛都崇拜. 思路:就是一 ...

随机推荐

  1. DataGridView控件绑定数据源

    前言: 近期听说DataGridView控件能直接绑定数据源.而不用穿越这层那层的忍辱负重.获取数据.真是高兴的屁颠屁颠的.后来一想二狗肯定不会弄.特意写了一个笨蛋版的教程--也算记录生活.欢度端午了 ...

  2. VBA调试利器debug.print

    作者:iamlaosong 百度一下.非常easy找到debug.print解释和使用介绍.事实上非常简单.就是将代码运行结果显示在"马上窗体"中,但不影响程序运行.VBA程序调试 ...

  3. Python实现的基于ADB的Android远程工具

    本工具为原创,涉及知识: - Python编程 - Tkinter GUI编程 - ADB通信机制 代码已经开源: https://code.csdn.net/codehat/andev/tree/m ...

  4. ubuntu-通配符

    ubuntu下的通配符主要有三个 1.*  这个是匹配任意一个或多个字符 ab1.txt ab2.txt ab3.txt abc.txt 执行命令以及结果如下 zhangshuli@zhangshul ...

  5. worktools-monkey 测试工具的使用

    配置电脑环境 1.进入用户目录下的bin cd ~/bin 2.链接一下monkey monkey -> /home/zhangshuli/git/vanzo_team/xulei/monkey ...

  6. Lightoj 1043 - Triangle Partitioning【二分】

    题目链接:http://lightoj.com/volume_showproblem.php? problem=1043 题意:一个三角形ABC,DE//BC.已知三角形ADE和四边形BDEC的面积的 ...

  7. python 序列排序 排序后返回相应的索引

    https://blog.csdn.net/longwei92/article/details/83098289 https://blog.csdn.net/u013731339/article/de ...

  8. Java Web学习总结(17)——JSP属性范围

    所谓的属性范围就是一个属性设置之后,可以经过多少个其他页面后仍然可以访问的保存范围. 一.JSP属性范围 JSP中提供了四种属性范围,四种属性范围分别指以下四种: 当前页:一个属性只能在一个页面中取得 ...

  9. JSP学习 —— 开篇:JSP,servlet容器,Tomcat,servlet容器之间的关系

    JSP(JAVA SERVER PAGE)的缩写,其本身就是servlet的简化,是一种动态网页标准,其特点是在HTML代码中嵌入JAVA代码,JSP标签或用户标签来生成网页.至于它为什么会出现,主要 ...

  10. [Node.js] Node Util Promisify - How to Convert Callback Based APIs to Promise-based

    Since Node.js V8.0+, it introduces a 'util' libaray, which has a 'promisfy' function. It can conver ...