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

  1. #include<cstdio>
  2. #include<algorithm>
  3. #define ll long long
  4. using namespace std;
  5. const int maxn=1e5+,maxm=1e6+;
  6.  
  7. int pre[maxn],low[maxn],clock;
  8. int head[maxn],e[maxm],nxt[maxm],cnt;
  9. int adde(int u,int v){
  10. e[++cnt]=v;nxt[cnt]=head[u];head[u]=cnt;
  11. e[++cnt]=u;nxt[cnt]=head[v];head[v]=cnt;
  12. }
  13. ll ans[maxn],t[maxn];
  14. int n,m,size[maxn];
  15.  
  16. int dfs(int u){
  17. pre[u]=low[u]=++clock;
  18. size[u]=;
  19. for(int i=head[u];i;i=nxt[i]){
  20. int v=e[i];
  21. if(pre[v]) low[u]=min(low[u],pre[v]);
  22. else{
  23. dfs(v);
  24. size[u]+=size[v];
  25. low[u]=min(low[u],low[v]);
  26. if(low[v]>=pre[u]){
  27. ans[u]+=t[u]*size[v];
  28. t[u]+=size[v];
  29. }
  30. }
  31. }
  32. ans[u]+=t[u]*(n-t[u]-);
  33. ans[u]=(ans[u]+n-)*;
  34. }
  35.  
  36. int main(){
  37. scanf("%d%d",&n,&m);
  38. int u,v;
  39. for(int i=;i<=m;i++){
  40. scanf("%d%d",&u,&v);
  41. adde(u,v);
  42. }
  43.  
  44. for(int i=;i<=n;i++)
  45. if(!pre[i]) dfs(i);
  46.  
  47. for(int i=;i<=n;i++)
  48. printf("%lld\n",ans[i]);
  49. return ;
  50. }

【dfs+连通分量】Bzoj1123 POI2008 BLO的更多相关文章

  1. BZOJ1123: [POI2008]BLO

    1123: [POI2008]BLO Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 614  Solved: 235[Submit][Status] ...

  2. BZOJ1123:[POI2008]BLO(双连通分量)

    Description Byteotia城市有n个 towns m条双向roads. 每条 road 连接 两个不同的 towns ,没有重复的road. 所有towns连通. Input 输入n&l ...

  3. bzoj1123 [POI2008]BLO——求割点子树相乘

    题目:https://www.lydsy.com/JudgeOnline/problem.php?id=1123 思路倒是有的,不就是个乘法原理吗,可是不会写...代码能力... 写了一堆麻麻烦烦乱七 ...

  4. BZOJ1123 [POI2008]BLO(割点判断 + 点双联通缩点size)

    #include <iostream> #include <cstring> #include <cstdio> using namespace std; type ...

  5. [BZOJ1123]:[POI2008]BLO(塔尖)

    题目传送门 题目描述 Byteotia城市有n个towns.m条双向roads.每条road连接两个不同的towns,没有重复的road.所有towns连通. 输入格式 输入n,m及m条边. 输出格式 ...

  6. 【BZOJ-1123】BLO Tarjan 点双连通分量

    1123: [POI2008]BLO Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 970  Solved: 408[Submit][Status][ ...

  7. BZOJ 1123: [POI2008]BLO

    1123: [POI2008]BLO Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 1030  Solved: 440[Submit][Status] ...

  8. BZOJ 1123: [POI2008]BLO( tarjan )

    tarjan找割点..不是割点答案就是(N-1)*2, 是割点的话就在tarjan的时候顺便统计一下 ------------------------------------------------- ...

  9. bzoj 1123 [POI2008]BLO Tarjan求割点

    [POI2008]BLO Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 1540  Solved: 711[Submit][Status][Discu ...

随机推荐

  1. 《深入理解Java虚拟机》读书笔记2--垃圾回收

    回收哪些内存/对象 引用计数算法 可达性分析算法 finalize()方法 HotSpot实现分析 转载:http://blog.csdn.net/tjiyu/article/details/5398 ...

  2. javascript初学者必须注意的7个细节

    [IT168 技术]每种语言都有它特别的地方,对于JavaScript来说,使用var就可以声明任意类型的变量,这门脚本语言看起来很简单,然而想要写出优雅的代码却是需要不断积累经验的.本文列举Java ...

  3. Django Web项目部署参考

    环境准备:1.Python 2.7.*]2.pip3.sudo pip install django4.sudo aptitude show python-setuptools5.sudo aptit ...

  4. Django开发环境静态文件访问配置

    settings主要配置项目: STATIC_ROOT = 'D:\Dev\jpDev\czxg\assets' #这个地方是所在系统标准目录文法配置 STATIC_URL = '/static/' ...

  5. HTML Meta信息的优先级

    一般来讲meta的信息都是不同维度的不会有冲突,不过下面两个有一定冲突: <meta name="renderer" content="webkit"&g ...

  6. neo4j-rest-client使用摘要

    1.使用它的原因,与django搭配的最好的neomodel目前只支持到v2.2,我已给官方发了issue,官方也回复了,马上修改并发布(老外对开源项目的负责态度让人感动) 2.这个库的文档中大概描述 ...

  7. RocketMQ源码 — 八、 RocketMQ消息重试

    RocketMQ的消息重试包含了producer发送消息的重试和consumer消息消费的重试. producer发送消息重试 producer在发送消息的时候如果发送失败了,RocketMQ会自动重 ...

  8. sudo pip install MySQLdb

    安装数据库第三方包,报错: Could not find a version that satisfies the requirement MySQLdb (from versions: )No ma ...

  9. Oracle解锁表笔记

    1.查询被锁的对象: select object_name,machine,s.sid,s.serial# from v$locked_object l,dba_objects o ,v$sessio ...

  10. RabbitMQ在windows系统安装部署文档

    1.RabbitMQ简介 MQ全称为Message Queue, 消息队列(MQ)是一种应用程序对应用程序的通信方法.应用程序通过读写出入队列的消息(针对应用程序的数据)来通信,而无需专用连接来链接它 ...