【dfs+连通分量】Bzoj1123 POI2008 BLO
Description
Byteotia城市有n个 towns m条双向roads. 每条 road 连接 两个不同的 towns ,没有重复的road. 所有towns连通。
Input
输入n<=100000 m<=500000及m条边
Output
输出n个数,代表如果把第i个点去掉,将有多少对点不能互通。
Solution
求割顶的一系列操作不仅可以用来求割顶,也可以解决很多问题,比如这道题。
dfs是很神奇的,对于节点u能扩展出去的v的子树是互相独立的,反向边也只会往上连。
那么对于u,他的父亲p和能连回去的v形成一个连通块,其余v各成一个连通块。
然后就很好统计了(细节自己想),其实用dfs树来处理大概就是树形dp。
Code
- #include<cstdio>
- #include<algorithm>
- #define ll long long
- using namespace std;
- const int maxn=1e5+,maxm=1e6+;
- int pre[maxn],low[maxn],clock;
- int head[maxn],e[maxm],nxt[maxm],cnt;
- int adde(int u,int v){
- e[++cnt]=v;nxt[cnt]=head[u];head[u]=cnt;
- e[++cnt]=u;nxt[cnt]=head[v];head[v]=cnt;
- }
- ll ans[maxn],t[maxn];
- int n,m,size[maxn];
- int dfs(int u){
- pre[u]=low[u]=++clock;
- size[u]=;
- for(int i=head[u];i;i=nxt[i]){
- int v=e[i];
- if(pre[v]) low[u]=min(low[u],pre[v]);
- else{
- dfs(v);
- size[u]+=size[v];
- low[u]=min(low[u],low[v]);
- if(low[v]>=pre[u]){
- ans[u]+=t[u]*size[v];
- t[u]+=size[v];
- }
- }
- }
- ans[u]+=t[u]*(n-t[u]-);
- ans[u]=(ans[u]+n-)*;
- }
- int main(){
- scanf("%d%d",&n,&m);
- int u,v;
- for(int i=;i<=m;i++){
- scanf("%d%d",&u,&v);
- adde(u,v);
- }
- for(int i=;i<=n;i++)
- if(!pre[i]) dfs(i);
- for(int i=;i<=n;i++)
- printf("%lld\n",ans[i]);
- return ;
- }
【dfs+连通分量】Bzoj1123 POI2008 BLO的更多相关文章
- BZOJ1123: [POI2008]BLO
1123: [POI2008]BLO Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 614 Solved: 235[Submit][Status] ...
- BZOJ1123:[POI2008]BLO(双连通分量)
Description Byteotia城市有n个 towns m条双向roads. 每条 road 连接 两个不同的 towns ,没有重复的road. 所有towns连通. Input 输入n&l ...
- bzoj1123 [POI2008]BLO——求割点子树相乘
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=1123 思路倒是有的,不就是个乘法原理吗,可是不会写...代码能力... 写了一堆麻麻烦烦乱七 ...
- BZOJ1123 [POI2008]BLO(割点判断 + 点双联通缩点size)
#include <iostream> #include <cstring> #include <cstdio> using namespace std; type ...
- [BZOJ1123]:[POI2008]BLO(塔尖)
题目传送门 题目描述 Byteotia城市有n个towns.m条双向roads.每条road连接两个不同的towns,没有重复的road.所有towns连通. 输入格式 输入n,m及m条边. 输出格式 ...
- 【BZOJ-1123】BLO Tarjan 点双连通分量
1123: [POI2008]BLO Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 970 Solved: 408[Submit][Status][ ...
- BZOJ 1123: [POI2008]BLO
1123: [POI2008]BLO Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 1030 Solved: 440[Submit][Status] ...
- BZOJ 1123: [POI2008]BLO( tarjan )
tarjan找割点..不是割点答案就是(N-1)*2, 是割点的话就在tarjan的时候顺便统计一下 ------------------------------------------------- ...
- bzoj 1123 [POI2008]BLO Tarjan求割点
[POI2008]BLO Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 1540 Solved: 711[Submit][Status][Discu ...
随机推荐
- 《深入理解Java虚拟机》读书笔记2--垃圾回收
回收哪些内存/对象 引用计数算法 可达性分析算法 finalize()方法 HotSpot实现分析 转载:http://blog.csdn.net/tjiyu/article/details/5398 ...
- javascript初学者必须注意的7个细节
[IT168 技术]每种语言都有它特别的地方,对于JavaScript来说,使用var就可以声明任意类型的变量,这门脚本语言看起来很简单,然而想要写出优雅的代码却是需要不断积累经验的.本文列举Java ...
- Django Web项目部署参考
环境准备:1.Python 2.7.*]2.pip3.sudo pip install django4.sudo aptitude show python-setuptools5.sudo aptit ...
- Django开发环境静态文件访问配置
settings主要配置项目: STATIC_ROOT = 'D:\Dev\jpDev\czxg\assets' #这个地方是所在系统标准目录文法配置 STATIC_URL = '/static/' ...
- HTML Meta信息的优先级
一般来讲meta的信息都是不同维度的不会有冲突,不过下面两个有一定冲突: <meta name="renderer" content="webkit"&g ...
- neo4j-rest-client使用摘要
1.使用它的原因,与django搭配的最好的neomodel目前只支持到v2.2,我已给官方发了issue,官方也回复了,马上修改并发布(老外对开源项目的负责态度让人感动) 2.这个库的文档中大概描述 ...
- RocketMQ源码 — 八、 RocketMQ消息重试
RocketMQ的消息重试包含了producer发送消息的重试和consumer消息消费的重试. producer发送消息重试 producer在发送消息的时候如果发送失败了,RocketMQ会自动重 ...
- sudo pip install MySQLdb
安装数据库第三方包,报错: Could not find a version that satisfies the requirement MySQLdb (from versions: )No ma ...
- Oracle解锁表笔记
1.查询被锁的对象: select object_name,machine,s.sid,s.serial# from v$locked_object l,dba_objects o ,v$sessio ...
- RabbitMQ在windows系统安装部署文档
1.RabbitMQ简介 MQ全称为Message Queue, 消息队列(MQ)是一种应用程序对应用程序的通信方法.应用程序通过读写出入队列的消息(针对应用程序的数据)来通信,而无需专用连接来链接它 ...