来源:
Central Europe 1996

思路:
Tarjan求割点。
一个点$x$为割点当且仅当:
  1.$x$为根结点且有两棵不相交的子树。
  2.$x$不为根结点且它的子树中没有可以返回到$x$的祖先的边。

实现细节:
  当$x$为根结点时,不能单纯地统计它的度,而是应该统计其不相交子树的个数,因为如果刚好是一个环,每个点的度都是$2$,但去掉这个点以后还是连通的。

  1. #include<cstdio>
  2. #include<vector>
  3. #include<cstring>
  4. const int V=;
  5. const int root=;
  6. std::vector<int> e[V];
  7. inline void add_edge(const int u,const int v) {
  8. e[u].push_back(v);
  9. }
  10. int dfn[V],low[V],cnt;
  11. bool isCut[V];
  12. void Tarjan(const int x) {
  13. int child=;
  14. dfn[x]=low[x]=++cnt;
  15. for(unsigned i=;i<e[x].size();i++) {
  16. int &y=e[x][i];
  17. if(!dfn[y]) {
  18. Tarjan(y);
  19. low[x]=std::min(low[x],low[y]);
  20. child++;
  21. if(x!=root&&low[y]>=dfn[x]) isCut[x]=true;
  22. if(x==root&&child>) isCut[x]=true;
  23. }
  24. else {
  25. low[x]=std::min(low[x],dfn[y]);
  26. }
  27. }
  28. }
  29. inline void init() {
  30. for(int i=;i<V;i++) e[i].clear();
  31. memset(dfn,,sizeof dfn);
  32. memset(low,,sizeof low);
  33. memset(isCut,,sizeof isCut);
  34. cnt=;
  35. }
  36. int main() {
  37. for(;;) {
  38. int n;
  39. scanf("%d",&n);
  40. if(!n) return ;
  41. init();
  42. for(;;) {
  43. int u;
  44. scanf("%d",&u);
  45. if(!u) break;
  46. while(getchar()!='\n') {
  47. int v;
  48. scanf("%d",&v);
  49. add_edge(u,v);
  50. add_edge(v,u);
  51. }
  52. }
  53. Tarjan(root);
  54. int ans=;
  55. for(int i=;i<=n;i++) {
  56. ans+=isCut[i];
  57. }
  58. printf("%d\n",ans);
  59. }
  60. }

[POJ1144]Network的更多相关文章

  1. POJ1144 Network(割点)题解

    Description A Telephone Line Company (TLC) is establishing a new telephone cable network. They are c ...

  2. POJ1144 Network 无向图的割顶

    现在打算重新学习图论的一些基础算法,包括像桥,割顶,双连通分量,强连通分量这些基础算法我都打算重敲一次,因为这些量都是可以用tarjan的算法求得的,这次的割顶算是对tarjan的那一类算法的理解的再 ...

  3. ZOJ1311, POJ1144 Network

    题目描述:TLC电话线路公司正在新建一个电话线路网络.他们将一些地方(这些地方用1到N的整数标明,任何2个地方的标号都不相同)用电话线路连接起来.这些线路是双向的,每条线路连接2个地方,并且每个地方的 ...

  4. poj1144 Network【tarjan求割点】

    转载请注明出处,谢谢:http://www.cnblogs.com/KirisameMarisa/p/4319585.html   ---by 墨染之樱花 [题目链接]http://poj.org/p ...

  5. POJ1144:Network(无向连通图求割点)

    题目:http://poj.org/problem?id=1144 求割点.判断一个点是否是割点有两种判断情况: 如果u为割点,当且仅当满足下面的1条 1.如果u为树根,那么u必须有多于1棵子树 2. ...

  6. [poj1144]Network(求割点模板)

    解题关键:割点模板题. #include<cstdio> #include<cstring> #include<vector> #include<stack& ...

  7. POJ1144 Network 无向图割点

    题目大意:求以无向图割点. 定义:在一个连通图中,如果把点v去掉,该连通图便分成了几个部分,则v是该连通图的割点. 求法:如果v是割点,如果u不是根节点,则u后接的边中存在割边(u,v),或者v-&g ...

  8. POJ1144 Network 题解 点双连通分量(求割点数量)

    题目链接:http://poj.org/problem?id=1144 题目大意:给以一个无向图,求割点数量. 这道题目的输入和我们一般见到的不太一样. 它首先输入 \(N\)(\(\lt 100\) ...

  9. 【poj1144】 Network

    http://poj.org/problem?id=1144 (题目链接) 题意 求无向图的割点. Solution Tarjan求割点裸题.并不知道这道题的输入是什么意思,也不知道有什么意义= =, ...

随机推荐

  1. JVM内存管理---垃圾收集器

    说起垃圾收集(Garbage Collection,GC),大部分人都把这项技术当做Java语言的伴生产物.事实上,GC的历史远比Java久远,1960年诞生于MIT的Lisp是第一门真正使用内存动态 ...

  2. bzoj千题计划195:bzoj2844: albus就是要第一个出场

    http://www.lydsy.com/JudgeOnline/problem.php?id=2844 题意:给定 n个数,把它的所有子集(可以为空)的异或值从小到大排序得到序列 B,请问 Q 在  ...

  3. Linux使用imagemagick的convert命令压缩图片、节省服务器空间

    一.安装: sudo apt-get install imagemagick 二.说明 imagemagick的命令convert可以完成此任务,其参数-resize用来改变图片尺寸,可以直接指定像素 ...

  4. 略显犀利的 js 判断闰年

    /** * 判断闰年函数 * @param {number} year 要判断的年份 * @return {bool} 返回布尔值 * * 其实只要满足下面几个条件即可. * 1.普通年能被4整除且不 ...

  5. 第5月第8天 jsonmodel

    1. @implementation JSONValueTransformer (CustomTransformer) //时间戳转NSDate - (NSDate *)NSDateFromNSStr ...

  6. 第6月第10天 svn checkout sqlite3

    1. http://www.cnblogs.com/xuling/p/5602036.html 2. http://blog.csdn.net/qq_26819733/article/details/ ...

  7. MacOS 下提示APP 损坏 无法安装 解决方法

    sudo spctl --master-disable

  8. lucene查询索引之Query子类查询——(七)

    0.文档名字:(根据名字索引查询文档)

  9. oracel回收站清理

    从powerdesigner中往oracle中导入表,出现了很多类似“BIN$Z35FPY7eFZDgUKjAC94NkA==$0 ”这样的表名, 原因是删除表的时候没有彻底的删除表,而是把表放入回收 ...

  10. Python学习三|列表、字典、元组、集合的特点以及类的一些定义

    此表借鉴于他人 定义 使用方法 列表 可以包含不同类型的对象,可以增减元素,可以跟其他的列表结合或者把一个列表拆分,用[]来定义的 eg:aList=[123,'abc',4.56,['inner', ...