hdu 3836 Equivalent Sets
题目连接
http://acm.hdu.edu.cn/showproblem.php?pid=3836
Equivalent Sets
Description
To prove two sets A and B are equivalent, we can first prove A is a subset of B, and then prove B is a subset of A, so finally we got that these two sets are equivalent.
You are to prove N sets are equivalent, using the method above: in each step you can prove a set X is a subset of another set Y, and there are also some sets that are already proven to be subsets of some other sets.
Now you want to know the minimum steps needed to get the problem proved.
Input
The input file contains multiple test cases, in each case, the first line contains two integers N <= 20000 and M <= 50000.
Next M lines, each line contains two integers X, Y, means set X in a subset of set Y.
Output
For each case, output a single integer: the minimum steps needed.
Sample Input
4 0
3 2
1 2
1 3
Sample Output
4
3
题目大意:给你一张有向图要求最少加多少条边时该图变成强连通图。
Tarjan缩点。。
- #include<bits/stdc++.h>
- using namespace std;
- const int N = 20100;
- struct Tarjan_scc {
- stack<int> s;
- bool instack[N];
- struct edge { int to, next; }G[N * 3];
- int idx, scc, tot, in[N], out[N], dfn[N], low[N], head[N], sccnum[N];
- inline void init(int n) {
- idx = scc = tot = 0;
- while (!s.empty()) s.pop();
- for (int i = 0; i < n + 2; i++) {
- head[i] = -1;
- instack[i] = false;
- in[i] = out[i] = dfn[i] = low[i] = sccnum[i] = 0;
- }
- }
- inline void add_edge(int u, int v) {
- G[tot].to = v, G[tot].next = head[u], head[u] = tot++;
- }
- inline void built(int m) {
- int u, v;
- while (m--) {
- scanf("%d %d", &u, &v);
- add_edge(u, v);
- }
- }
- inline void tarjan(int u) {
- dfn[u] = low[u] = ++idx;
- instack[u] = true;
- s.push(u);
- for (int i = head[u]; ~i; i = G[i].next) {
- int &v = G[i].to;
- if (!dfn[v]) {
- tarjan(v);
- low[u] = min(low[u], low[v]);
- } else if (instack[v] && dfn[v] < low[u]) {
- low[u] = dfn[v];
- }
- }
- if (dfn[u] == low[u]) {
- int v = 0;
- scc++;
- do {
- v = s.top(); s.pop();
- instack[v] = false;
- sccnum[v] = scc;
- } while (u != v);
- }
- }
- inline void solve(int n, int m) {
- init(n);
- built(m);
- for (int i = 1; i <= n; i++) {
- if (!dfn[i]) tarjan(i);
- }
- int x1 = 0, x2 = 0;
- for (int u = 1; u <= n; u++) {
- for (int i = head[u]; ~i; i = G[i].next) {
- int v = G[i].to;
- if (sccnum[u] != sccnum[v]) {
- in[sccnum[v]]++;
- out[sccnum[u]]++;
- }
- }
- }
- for (int i = 1; i <= scc; i++) {
- if (!in[i]) x1++;
- if (!out[i]) x2++;
- }
- printf("%d\n", 1 == scc ? 0 : max(x1, x2));
- }
- }go;
- int main() {
- #ifdef LOCAL
- freopen("in.txt", "r", stdin);
- freopen("out.txt", "w+", stdout);
- #endif
- int n, m;
- while (~scanf("%d %d", &n, &m)) {
- go.solve(n, m);
- }
- return 0;
- }
hdu 3836 Equivalent Sets的更多相关文章
- [tarjan] hdu 3836 Equivalent Sets
主题链接: http://acm.hdu.edu.cn/showproblem.php? pid=3836 Equivalent Sets Time Limit: 12000/4000 MS (Jav ...
- hdu 3836 Equivalent Sets trajan缩点
Equivalent Sets Time Limit: 12000/4000 MS (Java/Others) Memory Limit: 104857/104857 K (Java/Other ...
- hdu 3836 Equivalent Sets(强连通分量--加边)
Equivalent Sets Time Limit: 12000/4000 MS (Java/Others) Memory Limit: 104857/104857 K (Java/Other ...
- hdu——3836 Equivalent Sets
Equivalent Sets Time Limit: 12000/4000 MS (Java/Others) Memory Limit: 104857/104857 K (Java/Other ...
- hdu 3836 Equivalent Sets(tarjan+缩点)
Problem Description To prove two sets A and B are equivalent, we can first prove A is a subset of B, ...
- hdu - 3836 Equivalent Sets(强连通)
http://acm.hdu.edu.cn/showproblem.php?pid=3836 判断至少需要加几条边才能使图变成强连通 把图缩点之后统计入度为0的点和出度为0的点,然后两者中的最大值就是 ...
- HDU - 3836 Equivalent Sets (强连通分量+DAG)
题目大意:给出N个点,M条边.要求你加入最少的边,使得这个图变成强连通分量 解题思路:先找出全部的强连通分量和桥,将强连通分量缩点.桥作为连线,就形成了DAG了 这题被坑了.用了G++交的,结果一直R ...
- hdoj 3836 Equivalent Sets【scc&&缩点】【求最少加多少条边使图强连通】
Equivalent Sets Time Limit: 12000/4000 MS (Java/Others) Memory Limit: 104857/104857 K (Java/Other ...
- HUD——T 3836 Equivalent Sets
http://acm.hdu.edu.cn/showproblem.php?pid=3836 Time Limit: 12000/4000 MS (Java/Others) Memory Lim ...
随机推荐
- Flex4+BlazeDS+JAVA+MySql 构建J2EE工程 对用户信息进行管理实例
要求 必备知识 本文要求基本了解 Adobe Flex编程知识和JAVA基础知识. 开发环境 MyEclipse10/Flash Builder4.6/Flash Player11及以上 演示地址 演 ...
- 【LeetCode】8. String to Integer (atoi) 字符串转整数
题目: Implement atoi to convert a string to an integer. Hint: Carefully consider all possible input ca ...
- VC获取并修改计算机屏幕分辨率(MFC)
//检测当前分辨率 int Width = GetSystemMetrics(SM_CXSCREEN); int Height = GetSystemMetrics(SM_CYSCREEN); DEV ...
- HTTP 500.22 错误解决
打开网站对应的应用池-->高级设置-->托管管道模式改为classic
- imp-00002 无法打开。。
路径错了无疑 文件名少了个字符无疑 文件名错了无疑
- 设置lable文本内容的行间距
NSMutableParagraphStyle *paragraphStyle =[ [NSMutableParagraphStyle alloc] init]; paragraphStyle.lin ...
- Linux选型:开源不是免费 首选红帽和SUSE
首发:http://tech.it168.com/a2014/0324/1606/000001606245.shtml 企业级服务器系统选型报告:http://www.it168.com/redian ...
- node.js 快速体验
对于一个从事js的工作人员,怎么能不知道node.js呢! 一.安装node.js 在window上安装,http://nodejs.org上的windows installer 下载安装,在安装过程 ...
- JavaScript 性能优化1
一直在学习javascript,也有看过<犀利开发Jquery内核详解与实践>,对这本书的评价只有两个字犀利,可能是对javascript理解的还不够透彻异或是自己太笨,更多的是自己不擅于 ...
- linux ---用uniq实现文件的并集和交集
1. 取出两个文件的并集(重复的行只保留一份) 2. 取出两个文件的交集(只留下同时存在于两个文件中的文件) 3. 删除交集,留下其他的行 1. cat file1 file2 | sort | un ...