按B->A连边,tarjan缩点,然后找入度为0的连通分量,如果有1个,则ans=size[i],如果大于一个则ans=0;

当然如果按A->B连边就是找出度为0的(表示没有被它喜欢的,这样的连通分量才有可能所被所有的喜欢)

  1. /**************************************************************
  2. Problem: 1051
  3. User: Tunix
  4. Language: C++
  5. Result: Accepted
  6. Time:52 ms
  7. Memory:2308 kb
  8. ****************************************************************/
  9.  
  10. //BZOJ 1051
  11. #include<vector>
  12. #include<cstdio>
  13. #include<cstring>
  14. #include<cstdlib>
  15. #include<iostream>
  16. #include<algorithm>
  17. #define rep(i,n) for(int i=0;i<n;++i)
  18. #define F(i,j,n) for(int i=j;i<=n;++i)
  19. #define D(i,j,n) for(int i=j;i>=n;--i)
  20. using namespace std;
  21. const int N=;
  22.  
  23. void read(int &v){
  24. v=;int sign=; char ch=getchar();
  25. while(ch<'' || ch>'') {if (ch=='-') sign=-; ch=getchar();}
  26. while(ch>=''&&ch<=''){v=v*+ch-''; ch=getchar();}
  27. v*=sign;
  28. }
  29. /****************tamplate***********************/
  30. int n,m;
  31. int head[N],to[N*],next[N*],cnt;
  32. void add(int a,int b){
  33. to[++cnt]=b; next[cnt]=head[a]; head[a]=cnt;
  34. }
  35. int dfn[N],low[N],belong[N],du[N],dfs_clock,size[N],SCC;
  36. bool inst[N];
  37. int st[N],top;
  38. void tarjan(int x){
  39. int y;
  40. dfn[x]=low[x]=++dfs_clock;
  41. st[top++]=x;
  42. inst[x]=;
  43. for(int i=head[x];i;i=next[i]){
  44. y=to[i];
  45. if (!dfn[y]){
  46. tarjan(y);
  47. low[x]=min(low[x],low[y]);
  48. }
  49. else if (inst[y]) low[x]=min(low[x],dfn[y]);
  50. }
  51. if (dfn[x]==low[x]){
  52. SCC++;size[SCC]=;
  53. for(y=;y!=x;){
  54. y=st[--top];
  55. inst[y]=;
  56. belong[y]=SCC;
  57. size[SCC]++;
  58. }
  59. }
  60. }
  61. void rebuild(){
  62. F(x,,n)
  63. for(int i=head[x];i;i=next[i])
  64. if (belong[x]!=belong[to[i]]) du[belong[to[i]]]++;
  65. }
  66. /***********************************************/
  67. int main(){
  68. read(n); read(m);
  69. int a,b;
  70. F(i,,m){
  71. read(a); read(b);
  72. add(b,a);
  73. }
  74. F(i,,n) if (!dfn[i]) tarjan(i);
  75. rebuild();
  76. int ans=;
  77. if (SCC==) ans=n;
  78. else{
  79. int tot=;
  80. F(i,,SCC) if (du[i]==) {tot++; ans=size[i];}
  81. if (tot>) ans=;
  82. }
  83. printf("%d\n",ans);
  84. return ;
  85. }

【BZOJ】【1051】【HAOI2005】受欢迎的牛的更多相关文章

  1. BZOJ 1051 最受欢迎的牛 解题报告

    题目直接摆在这里! 1051: [HAOI2006]受欢迎的牛 Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 4438  Solved: 2353[S ...

  2. BZOJ 1051: [HAOI2006]受欢迎的牛 缩点

    1051: [HAOI2006]受欢迎的牛 Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://www.lydsy.com/JudgeOnline/ ...

  3. bzoj 1051: [HAOI2006]受欢迎的牛 tarjan缩点

    1051: [HAOI2006]受欢迎的牛 Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 2092  Solved: 1096[Submit][Sta ...

  4. BZOJ 1051: [HAOI2006]受欢迎的牛( tarjan )

    tarjan缩点后, 有且仅有一个出度为0的强连通分量即answer, 否则无解 ----------------------------------------------------------- ...

  5. BZOJ 1051: [HAOI2006]受欢迎的牛(SCC)

    1051: [HAOI2006]受欢迎的牛 Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 8172  Solved: 4470[Submit][Sta ...

  6. bzoj 1051 (强连通) 受欢迎的牛

    题目:这里 题意: Description 每一头牛的愿望就是变成一头最受欢迎的牛.现在有N头牛,给你M对整数(A,B),表示牛A认为牛B受欢迎. 这 种关系是具有传递性的,如果A认为B受欢迎,B认为 ...

  7. 洛谷 P2341 BZOJ 1051 [HAOI2006]受欢迎的牛

    题目描述 每头奶牛都梦想成为牛棚里的明星.被所有奶牛喜欢的奶牛就是一头明星奶牛.所有奶 牛都是自恋狂,每头奶牛总是喜欢自己的.奶牛之间的“喜欢”是可以传递的——如果A喜 欢B,B喜欢C,那么A也喜欢C ...

  8. BZOJ 1051: [HAOI2006]受欢迎的牛

    Description 一个有向图,求所以能被别的点到达的点的个数. Sol Tarjan + 强连通分量 + 缩点. 缩点以后找强连通分量,缩点,然后当图有且仅有1个出度为1的点时,有答案. Cod ...

  9. BZOJ 1051: [HAOI2006]受欢迎的牛 强连通缩点

    题目链接: http://www.lydsy.com/JudgeOnline/problem.php?id=1051 题解: 强连通缩点得到DAG图,将图转置一下,对入度为零的点跑dfs看看能不能访问 ...

  10. bzoj 1051: [HAOI2006]受欢迎的牛 (Tarjan 缩点)

    链接:https://www.lydsy.com/JudgeOnline/problem.php?id=1051 思路: 首先用Tarjan把环缩成点,要想收到所有人的欢迎,那么这个点的出度必为0,且 ...

随机推荐

  1. python中字典dict pop方法

    首先引用下pythondoc pop(key[, default]) If key is in the dictionary, remove it and return its value, else ...

  2. 实例介绍Cocos2d-x开关菜单

    开关菜单是MenuItemToggle类实现的,它是一种可以进行两种状态切换的菜单.它可以通过下面的函数创建: static MenuItemToggle*createWithCallback  ( ...

  3. Coarse-Grained lock 粗粒度锁

    用一个锁Lock一组相关的对象 有时,需要按组来修改多个对象. 这样,在需要锁住其中一个的时候,必须连带地将其他的对象都上锁. 为每一个对象都加上一个锁是很繁琐的. 粗粒度锁是覆盖多个对象的单个锁. ...

  4. AR模式

    AR模式 在ThinkPHP框架中,一共存在两种操作模式:ORM模式与AR模式 ORM模式:① 实例化模型 ② 创建数据对象组装数组 ③ 调用相关方法执行相关操作 AR模式:① 实例化模型 ② 把数据 ...

  5. 简单工厂(Simple Pattern)模式

    一.简单工厂(Simple Factory)模式 Simple Factory 模式根据提供给它的数据,返回几个可能类中的一个类的实例.通常它返回的类都有一个公共的父类和公共的方法. Simple F ...

  6. Linux--变量与虚拟内存

    定义一个变量:存储类型  数据类型  变量名 存储类型(变量存储的位置):auto.register.static.extern 1.auto:对于局部变量,atuo可以缺省.位置:栈 2.exter ...

  7. 转:12种JavaScript MVC框架之比较

    Gordon L. Hempton是西雅图的一位黑客和设计师,他花费了几个月的时间研究和比较了12种流行的JavaScript MVC框架,并在博客中总结了每种框架的优缺点,最终的结果是,Ember. ...

  8. 33选6算法:M个数N个为一组,无重复的排列组合

    private void button1_Click(object sender, EventArgs e) { int nCnt = 0; List nNumList = new List(); f ...

  9. PHP操作MongoDB简明教程(转)

    转自:http://blog.sina.com.cn/s/blog_6324c2380100ux2m.html MongoDB是最近比较流行的NoSQL数据库,网络上关于PHP操作MongoDB的资料 ...

  10. Android NDK环境配置

    之前做了一个基于ffmpeg的软解播放器,熟悉了NDK开发的配置环境过程,但是由于太忙一直没有时间写笔记. 首先,介绍一下在这里所参与协作的软件包: 1. JDK: 这个软件被Eclipse依赖. 2 ...