题目链接:http://codeforces.com/gym/100676/attachments

题意:

有 n 个点,m 条边,图中,边强连通分量之间可以直达,即距离为 0 ,找一个点当做首都,其他点到首都的最大距离最小。

参考:http://www.cnblogs.com/ost-xg/p/6395100.html

仔细研究了大佬的思路,很牛逼,但是也有一点细节遗漏了,但是还是能AC,interesting;

分析:

边双连通:条件比点双连通松一点,体现在程序中,就是存在一个子节点能到达的最早祖先在父节点之后(没有等于);这样桥就找到了,然后再去找边双连通分量——dfs,从一个点出发,是桥就不是同一个边双连通分量;

这样就把题目中的边双连通分量找出来了;

然后缩点重新建图ed的边集!!!(遍历每一条边,是桥就加上来,大佬的这里多加了哦)

此时,怎么选首都呢?

其实,现在图已经是一棵树了,遍历每一个点跑最短路是傻逼行为;

先找到树的直径,首都一定在这条直径上,枚举直径上的点,最远的,不过是直径上的两个部分;

 #include <bits/stdc++.h>

 using namespace std;

 const int maxn = ;
const long long inf = 1e15 + ; struct Edge
{
long long u, v, c;
} e[maxn<<];
struct Ed
{
long long v, c;
}; int n, m, low[maxn], pre[maxn], tim, ebcc_cnt, du[maxn];
long long k, len, dis[maxn][];
vector<int> G[maxn];
vector<Ed> ed[maxn];
int isbri[maxn<<];
bool vis[maxn]; void init()
{
ebcc_cnt = tim = ;
for (int i = ; i <= n; i++) G[i].clear();
memset(isbri, , sizeof(isbri));
memset(pre, , sizeof(pre));
memset(du, , sizeof(du));
} void tarjan(int u, int fa)
{
low[u] = pre[u] = ++tim;
for (int i = ; i < G[u].size(); i++)
{
int tmp = G[u][i];
int v = e[tmp].v;
if (!pre[v])
{
tarjan(v, u);
low[u] = min(low[u], low[v]);
if (low[v] > pre[u])
isbri[tmp] = isbri[tmp^] = true; //标记为桥
}
else if (fa != v)
low[u] = min(low[u], pre[v]);
}
} void dfs(int u)
{
pre[u] = ebcc_cnt;
for (int i = ; i < G[u].size(); i++)
{
int tmp = G[u][i];
if (isbri[tmp]) continue;
int v = e[tmp].v;
if (pre[v]) continue;
dfs(v);
}
} void find_ebcc()
{
tarjan(, -);
memset(pre, , sizeof(pre));
for (int i = ; i <= n; i++)
{
if (!pre[i])
{
ebcc_cnt++;
dfs(i);
}
}
} void BFS(int s, int ca)
{
memset(vis, , sizeof(vis));
queue<Ed> q;
q.push((Ed)
{
s,
});
vis[s] = ;
while (q.size())
{
Ed tmp = q.front();
q.pop();
dis[tmp.v][ca] = tmp.c;
for (int i = ; i < ed[tmp.v].size(); i++)
{
Ed xx = ed[tmp.v][i];
if (!vis[xx.v])
{
vis[xx.v] = ;
q.push((Ed)
{
xx.v, xx.c + tmp.c
});
}
}
}
} void dfs_len(int x, int fa, long long dep)
{
if (dep > len)
{
k = x;
len = dep;
}
for (int i = ; i < ed[x].size(); i++)
{
Ed tmp = ed[x][i];
if (tmp.v == fa) continue;
dfs_len(tmp.v, x, dep + tmp.c);
}
} int main()
{
int t = ;
cin >> t; while (t--)
{
cin >> n >> m;
init();
for (int i = ; i <= m; i++)
{
int u, v, c;
scanf("%d%d%d", &u, &v, &c);
e[i<<|].u = u, e[i<<|].v = v, e[i<<|].c = c;
e[i<<].u = v, e[i<<].v = u, e[i<<].c = c;
G[u].push_back(i<<|);
G[v].push_back(i<<);
}
find_ebcc();
int tot = m<<|;
for (int i = ; i <= ebcc_cnt; i++) ed[i].clear();
for (int i = ; i <= tot; i += )
{
if (isbri[i])
{
int u = e[i].v, v = e[i].u;
ed[pre[u]].push_back((Ed)
{
pre[v], e[i].c
});
ed[pre[v]].push_back((Ed)
{
pre[u], e[i].c
});
}
}
len = -;
dfs_len(, -, );
int st = k;
len = -;
dfs_len(st, -, );
BFS(st, );
BFS(k, );
long long inx = n + , dd = inf;
for (int i = ; i <= n; i++)
{
int pr = pre[i];
if (dis[pr][] + dis[pr][] != len) continue;
long long tmp = max(dis[pr][], dis[pr][]);
if (tmp < dd)
{
inx = i;
dd = tmp;
}
}
printf("%lld %lld\n",inx,dd);
}
return ;
}

ACM Arabella Collegiate Programming Contest 2015 H. Capital City 边连通分量的更多相关文章

  1. ACM Arabella Collegiate Programming Contest 2015 F. Palindrome 并查集

    题目链接:http://codeforces.com/gym/100676/attachments 题意: 给一个字符串,有一些约束条件,两个位置要相同,有一些是问号,求最后有多少种方案回文? 分析: ...

  2. Codeforces Gym 2015 ACM Arabella Collegiate Programming Contest(二月十日训练赛)

    A(By talker): 题意分析:以a(int) op b(int)形式给出两个整数和操作符, 求两个整数是否存在操作符所给定的关系 ,有则输出true,无则输出false: 思路:由于无时间复杂 ...

  3. gym100676 [小熊骑士限定]2015 ACM Arabella Collegiate Programming Contest

    Kuma Rider久违的第二场训练,这场很水,又在vj的榜单上看到第一场的大哥了,2小时ak,大哥牛啤! A.水 #include<cstdio> #include<iostrea ...

  4. 2015 ACM Arabella Collegiate Programming Contest

    题目链接:https://vjudge.net/contest/154238#overview. ABCDE都是水题. F题,一开始分类讨论,结果似乎写挫了,WA了一发.果断换并查集上,A了. G题, ...

  5. 边双连通缩点+树dp 2015 ACM Arabella Collegiate Programming Contest的Gym - 100676H

    http://codeforces.com/gym/100676/attachments 题目大意: 有n个城市,有m条路,每条路都有边长,如果某几个城市的路能组成一个环,那么在环中的这些城市就有传送 ...

  6. 2017 ACM Arabella Collegiate Programming Contest(solved 11/13)

    省选考前单挑做点ACM练练细节还是很不错的嘛- 福利:http://codeforces.com/gym/101350 先来放上惨不忍睹的virtual participate成绩(中间跑去食堂吃饭于 ...

  7. 带权并查集:CF-2015 ACM Arabella Collegiate Programming Contest(F题)

    F. Palindrome Problem Description A string is palindrome if it can be read the same way in either di ...

  8. 容斥 或者 单调栈 hihocoder #1476 : 矩形计数 和 G. Snake Rana 2017 ACM Arabella Collegiate Programming Contest

    先说一个简单的题目(题目大意自己看去,反正中文):hihocoder上的:http://hihocoder.com/problemset/problem/1476 然后因为这个n和m的矩阵范围是100 ...

  9. 脑洞 博弈 E. Competitive Seagulls 2017 ACM Arabella Collegiate Programming Contest

    题目链接:http://codeforces.com/gym/101350/problem/E 题目大意:给你一个长度为n的方格,方格上面都被染色成了白色.每次染色都是选择白色的,假设目前选择的这块白 ...

随机推荐

  1. js中url有中文的转码方法

    转载:https://www.cnblogs.com/chiangfai/p/6073000.html

  2. itchat教程

    https://www.python.org/ftp/python/3.6.6/ https://www.python.org/ftp/python/3.6.6/Python-3.6.6.tar.xz ...

  3. Android 5.0以上heads up通知

    适用Android系统: 1) Android版本>= 5.0 2) 部分ROM是不支持 RemoteViews view=getRemoteViews(body,title, R.mipmap ...

  4. python fork函数

    import os print('---父进程id:%s----'%(os.getpid())) pid=os.fork()#只能在liunx环境下执行 print('---%s---' % (os. ...

  5. jemeter排至数据库时报:Access denied for user 'root'@'localhost' (using password:YES) 解决方案

    相信这个问题大部分人都遇到过,至少我遇到过三次了,而且每次原因都不一样,前段时间同学也遇到这个问题,问我怎么解决,我把我的解决思路都说了一遍,发现还不行,最后居然是另外一个原因...哎,说多了都是泪, ...

  6. Node调试之node-inspect工具

    1.全局安装node-inspect模块: npm install -g node-inspect 2.通过谷歌浏览器打开:chrome://flags/#enable-devtools-experi ...

  7. 如何在smarty模板中执行php代码

    Smarty模板主要的目的是分离逻辑层和表现层,所以在模板中不应该包含逻辑部分,逻辑层也不应该含有HTML.要在模板中插入逻辑程序的这种做法"非常"不被推荐,在你的case中. 如 ...

  8. python 在windows下监听键盘按键

    python 在windows下监听键盘按键 使用到的库 ctypes(通过ctypes来调用Win32API, 主要就是调用钩子函数) 使用的Win32API SetWindowsHookEx(), ...

  9. android 官网访问不了

    网上搜到的解决方案,亲测有用.记下来,以备遗忘. 使用管理员权限,修改C:\Windows\System32\Drivers\etc\hosts文件,加入以下内容 173.194.127.7 deve ...

  10. NOPI导出execl 多个sheet,一列图片

    NPOI API: http://www.cnblogs.com/atao/archive/2009/11/15/1603528.html http://blog.csdn.net/pan_junbi ...