洛谷 P2341 【HAOI2006】受欢迎的牛
题目链接
https://www.luogu.org/problem/P2341
分析
Tarjan缩点,最后DAG中,唯一的出度为 000 的点的大小即为答案。
AC代码
#include <cstdio>
#include <algorithm>
#include <stack>using namespace std;inline int read() {int num = 0;char c = getchar();while (c < '0' || c > '9') c = getchar();while (c >= '0' && c <= '9')num = num * 10 + c - '0', c = getchar();return num;
}const int maxn = 1e4 + 5, maxm = 5e4 + 5;int head[maxn], eid;struct Edge {int v, next;
} edge[maxm];inline void insert(int u, int v) {edge[++eid].v = v;edge[eid].next = head[u];head[u] = eid;
}int dfn[maxn], low[maxn], tot, scc[maxn], num[maxn], cnt, out[maxn], ans;
stack<int> s;void tarjan(int u) {dfn[u] = low[u] = ++tot;s.push(u);for (int p = head[u]; p; p = edge[p].next) {int v = edge[p].v;if (!dfn[v]) tarjan(v), low[u] = min(low[u], low[v]);else low[u] = min(low[u], dfn[v]);}if (low[u] == dfn[u]) {++cnt;while (s.top() != u) scc[s.top()] = cnt, ++num[cnt], s.pop();scc[u] = cnt, ++num[cnt], s.pop();}
}int main() {int n = read(), m = read();for (int i = 1; i <= m; ++i) {int u = read(), v = read();insert(u, v);}for (int i = 1; i <= n; ++i)if (!dfn[i]) tarjan(i);for (int u = 1; u <= n; ++u)for (int p = head[u]; p; p = edge[p].next) {int v = edge[p].v;if (scc[u] != scc[v]) ++out[scc[u]];}for (int i = 1; i <= cnt; ++i)if (!out[i]) {if (!ans) ans = num[i];else {ans = 0;break;}}printf("%d", ans);return 0;
}
洛谷 P2341 【HAOI2006】受欢迎的牛相关推荐
- 洛谷——P2341 [HAOI2006]受欢迎的牛//POJ2186:Popular Cows
P2341 [HAOI2006]受欢迎的牛/POJ2186:Popular Cows 题目背景 本题测试数据已修复. 题目描述 每头奶牛都梦想成为牛棚里的明星.被所有奶牛喜欢的奶牛就是一头明星奶牛.所 ...
- 洛谷P2341 [HAOI2006]受欢迎的牛 (Tarjan,SCC缩点)
P2341 [HAOI2006]受欢迎的牛|[模板]强连通分量 https://www.luogu.org/problem/P2341 题目描述 每头奶牛都梦想成为牛棚里的明星.被所有奶牛喜欢的奶牛就 ...
- 洛谷 P2341 [HAOI2006]受欢迎的牛
题目 题目背景 本题测试数据已修复. 题目描述 每头奶牛都梦想成为牛棚里的明星.被所有奶牛喜欢的奶牛就是一头明星奶牛.所有奶 牛都是自恋狂,每头奶牛总是喜欢自己的.奶牛之间的"喜欢" ...
- 洛谷P2341(受欢迎的牛)题解
题目描述 每头奶牛都梦想成为牛棚里的明星.被所有奶牛喜欢的奶牛就是一头明星奶牛.所有奶 牛都是自恋狂,每头奶牛总是喜欢自己的.奶牛之间的"喜欢"是可以传递的--如果A喜 欢B,B喜 ...
- 【luogu P2341 [HAOI2006]受欢迎的牛】 题解
题解报告:https://www.luogu.org/problemnew/show/P2341 我们把图中的强连通分量缩点,然后只有出度为0的牛是受欢迎的,这样如果出度为0的牛只有一个,说明受所有牛 ...
- P2341 [HAOI2006]受欢迎的牛 强连通
题目背景 本题测试数据已修复. 题目描述 每头奶牛都梦想成为牛棚里的明星.被所有奶牛喜欢的奶牛就是一头明星奶牛.所有奶 牛都是自恋狂,每头奶牛总是喜欢自己的.奶牛之间的"喜欢"是可 ...
- P2341 [HAOI2006]受欢迎的牛 (tarjan缩点+出度)
题意: 每头奶牛都梦想成为牛棚里的明星.被所有奶牛喜欢的奶牛就是一头明星奶牛.所有奶牛都是自恋狂,每头奶牛总是喜欢自己的.奶牛之间的"喜欢"是可以传递的--如果A喜欢B,B喜欢C, ...
- Luogu P2341 [HAOI2006]受欢迎的牛
这道题应该也是经典的SCC题了吧 印象中不知道在在班里上课的时候在紫书,ACM竞赛的那些书上看到多少次(有点奇怪) 首先思路很明显,就是要找出有多少个点,以它们为起点可以遍历整个图 首先考虑一种情况, ...
- 洛谷·[HAOI2006]受欢迎的牛
初见安~这里是传送门:洛谷P2341 题目描述 每头奶牛都梦想成为牛棚里的明星.被所有奶牛喜欢的奶牛就是一头明星奶牛.所有奶 牛都是自恋狂,每头奶牛总是喜欢自己的.奶牛之间的"喜欢" ...
- 洛谷 P2341 - 受欢迎的牛
题目描述 P2341 [USACO03FALL][HAOI2006]受欢迎的牛 G 解法: 首先,明确一下什么是明星奶牛:受欢迎的牛只可能是图中唯一的出度为0的强连通分量中的所有奶牛. 为什么? 强连 ...
最新文章
- 接口 类型转换 try-catch(学习笔记)
- apriori算法代码python_Apriori算法的Python实现
- 批量修改栏目名_Endnote中英文混排批量修改小技巧
- FreeBSD与Linux的比较
- [Windows Server 2012] 安装IIS8.5及FTP
- Lesson 6: CronTrigger
- 大陆和香港手机号正则校验
- ByPass Mode(略过模式或旁路模式)
- Learning from class-imbalanced data: Review of methods and applications 论文阅读
- 数字时代带给孩子们的只有“冰冷”的科技吗?_数字体验_新浪博客
- ioi 赛制_杨骏昭IOI2019参赛总结
- 喇叭的灵敏度代表什么
- <C++ 初阶> C++入门
- CentOS安装PostgreSQL各版本
- 牛客BM99-顺时针旋转矩阵-C++
- 【干货】超强整理19个辅助制作H5的工具/网站
- 兔子、狼、老虎的故事
- AI也是有局限性!看看机器人组装Ikea家具时的表现
- 大数据 hadoop 应用案例
- 毕业论文-降重技巧总结