Codeforces732F Tourist Reform
求出无向图的所有边双联通分量,然后缩点就成了一颗树。
然后我们选取最大的那个边双联通分量作为根,这样我们就可以确定所有割边的方向了。
对于边双联通分量里面的边,我们随便dfs一下就可以把它变成强连通分量,方向也就确定了。
#include <bits/stdc++.h>
using namespace std; vector<int> G[];
vector<pair<int, int>> G2[];
set<pair<int, int>> bridge;
set<pair<int, int>> ansset;
pair<int, int> old[];
int vis[];
int dfn[];
int low[];
int tag[]; void get_bridge(int cur, int father, int dep)
{
vis[cur] = ;
dfn[cur] = low[cur] = dep;
int children = ;
for (auto to : G[cur])
{
if (to != father && vis[to] == )
{
if (dfn[to] < low[cur])
low[cur] = dfn[to];
}
if (vis[to] == )
{
get_bridge(to, cur, dep + );
children++;
if (low[to] < low[cur])
low[cur] = low[to];
if (low[to] > dfn[cur])
bridge.insert({cur, to}), bridge.insert({to, cur});
}
}
vis[cur] = ;
} int dfs(int u, int tot)
{
int cnt = ;
vis[u] = true;
tag[u] = tot;
for (auto to : G[u])
{
if (ansset.find({u, to}) == ansset.end() && ansset.find({to, u}) == ansset.end() && bridge.find({u, to}) == bridge.end())
{
ansset.insert({u, to});
if (!vis[to])
cnt += dfs(to, tot);
}
}
return cnt;
} void dfs2(int cur, int fa)
{
for (auto e : G2[cur])
{
int nxt = tag[e.second];
if (nxt != fa)
{
ansset.insert({e.second, e.first});
dfs2(nxt, cur);
}
}
} int main()
{
int n, m;
scanf("%d%d", &n, &m);
int u, v;
for (int i = ; i < m; i++)
{
scanf("%d%d", &u, &v);
G[u].push_back(v);
G[v].push_back(u);
old[i] = {u, v};
}
get_bridge(, -, );
memset(vis, , sizeof(vis));
int ans = ;
int tot = ;
int idx = ;
for (int i = ; i <= n; i++)
{
if (!vis[i])
{
int siz = dfs(i, ++tot);
if (siz > ans)
ans = siz, idx = tot;
}
}
for (auto e : bridge)
G2[tag[e.first]].push_back(e);
dfs2(idx, -);
printf("%d\n", ans);
for (int i = ; i < m; i++)
{
if (ansset.find(old[i]) == ansset.end())
printf("%d %d\n", old[i].second, old[i].first);
else
printf("%d %d\n", old[i].first, old[i].second);
}
return ;
}
Codeforces732F Tourist Reform的更多相关文章
- 732F Tourist Reform
// CF 732F Tourist Reform // 思路:两遍tarjan // 找强联通分量 #include <bits/stdc++.h> using namespace st ...
- CodeForces 732F Tourist Reform
边双连通分量. 这题有一点构造的味道.一个有向图,经过强连通缩点之后会形成一个有向无环图. 如果将最大的强连通分量放在顶端,其余的强连通分量都直接或间接指向他,那么这样就构造出了符合要求的图. 接下来 ...
- CF 732F Tourist Reform——v-SCC+dfs
题目:http://codeforces.com/contest/732/problem/F 给无向图定向使得从每个点出发能去的点数最小值最大. SCC.点内部dfs定向.点间以siz最大的为起点反向 ...
- Codeforces Round #377 (Div. 2) F - Tourist Reform
前言:关于如何求双连通分量,我们可以在tarjan搜索时标记下所有桥的位置(双连通分量(可以认为是没有桥的无向图图)即可通过删去所有桥得到),那么怎么找桥呢,对于每一条搜索到的边u->x,如果l ...
- Codeforces 732F. Tourist Reform (Tarjan缩点)
题目链接:http://codeforces.com/problemset/problem/732/F 题意: 给出一个有n个点m条边的无向图,保证联通,现在要求将所有边给定一个方向使其变成有向图,设 ...
- CF732 F Tourist Reform——边双连通分量
题目:http://codeforces.com/contest/732/problem/F 首先把边双缩点,边双内部 dfs 一个顺序一定是可以从每个点走到边双内部所有点的,因为它是以环为基本单位: ...
- 【codeforces 732F】Tourist Reform
[题目链接]:http://codeforces.com/contest/732/problem/F [题意] 给你一张无向图; n个点,m条边; 让你把这张图改成有向边 然后定义r[i]为每个点能够 ...
- CF732F Tourist Reform(边双联通)
题意 在一张有向图中,设 ri 为从点 i 出发能够到达的点的数量. 定义有向图的“改良值”为 ri 的最小值. 现给出一张无向图,要求给每条边定一个方向,使产生的有向图“改良值”最大. 输出 最大改 ...
- CF732F Tourist Reform[边双缩点]
题意:给无向图每一条边定向,使得每个点可达点数$R_i$最小值尽可能大,求方案. 条件反射想到二分答案,然后看怎么检验,发现要让所有点$R_i$大于等于某一个值,首先我们关注某些特殊的子图:如果有环的 ...
随机推荐
- ormlite
id 主键 默认为false generatedId 自增长的主键 默认值是false generatedIdSequence 字符串名称的序列号 类同generatedId,但您可以指定序列的名称使 ...
- Java学习之基本概念
1.java体系结构: j2se:是Java的标准版,用于标准的应用开. j2ee:是Java的企业版,用于企业级的应用服务,web服务开发. j2me:是Java的微型版,用户手机或嵌入式开发. p ...
- requirejs中的define
关于requirejs中的define的原理理解 我们已经了解到模块模式是为单例创建私有变量和特权方法的.一个最基本的例子: var foo=(function(){ var something= ...
- vue 计算属性与侦听器
侦听器:顾名思义,就是用来监听数据变化用的.侦听器在vue实例中,定义变量watch来使用.监听新值newVal和旧值oldVal,具体使用方法如下: <!DOCTYPE html> &l ...
- LeetCode题解(14)--Longest Common Prefix
https://leetcode.com/problems/longest-common-prefix/ 原题: Write a function to find the longest common ...
- BZOJ 4197: [Noi2015]寿司晚宴 状态压缩 + 01背包
4197: [Noi2015]寿司晚宴 Time Limit: 10 Sec Memory Limit: 512 MB Description 为了庆祝 NOI 的成功开幕,主办方为大家准备了一场寿 ...
- SpringInAction4笔记——装配
重点:常用的上下文环境 AnnotationConfigApplicationContext ClassPathXmlApplicationContext FileSystemXmlApplicati ...
- ios对于枚举的使用
引言: 枚举值 它是一个整形(int) 并且,它不参与内存的占用和释放,枚举定义变量即可直接使用,不用初始化. 在代码中使用枚举的目的只有一个,那就是增加代码的可读性. 使用: 枚举的定义如下: t ...
- JVM垃圾回收算法 及 垃圾收集器
摘自<深入理解Java虚拟机> 一.什么是: GC算法是 方法论,那么垃圾收集器就是具体的 实现. 二.四种 垃圾回收算法 1.标记-清除算法:最基础的收集算法:不足有两点:1标记和清除两 ...
- hrtimer高精度定时器的简单使用【学习笔记】
#include <linux/module.h> #include <linux/kernel.h> #include <linux/hrtimer.h> #in ...