这道题应该也是经典的SCC题了吧

印象中不知道在在班里上课的时候在紫书,ACM竞赛的那些书上看到多少次(有点奇怪)

首先思路很明显,就是要找出有多少个点,以它们为起点可以遍历整个图

首先考虑一种情况,这种情况是多数SCC题目的突破口,即:环对题目的影响

我们发现,对于这道题,我们如果把环缩点,那么还是一样的

因为一个环中所有点都可以互相到达,因此缩点后每一个点内部相当于都可以直接到达,我们只需要统计一下每一个SCC中有多少个点然后就等价了

这里有一个结论,还是挺有用的:

在有向图中,如果有且仅有一个点的出度为0 (没有指向其他点的边),那么该点可以被所有点遍历到;反之,该图中没有可以被所有点遍历到的点

证明(都没有dalao给出证明,那我还是证一下好了):用反证法

假设有多个点的出度为0,我们设其中一个点为x,另一个点为y

因为它们的出度为0,那么我们知道x,y之间必然没有边

那么x必然无法遍历到y,因为x,y出度均为0,所以x也无法通过间接关系遍历到y

假设不成立,原命题得证。

然后就按上面的想法看一下出度为0的点是否唯一即可

CODE

  1. #include<cstdio>
  2. #include<cstring>
  3. using namespace std;
  4. const int N=10005;
  5. struct edge
  6. {
  7. int to,next;
  8. }e[N*5];
  9. int head[N],dfn[N],low[N],stack[N],col[N],t[N],chu[N],n,m,x,y,cnt,tot,top,sum,ans=-1;
  10. bool vis[N];
  11. inline char tc(void)
  12. {
  13. static char fl[100000],*A=fl,*B=fl;
  14. return A==B&&(B=(A=fl)+fread(fl,1,100000,stdin),A==B)?EOF:*A++;
  15. }
  16. inline void read(int &x)
  17. {
  18. x=0; char ch=tc();
  19. while (ch<'0'||ch>'9') ch=tc();
  20. while (ch>='0'&&ch<='9') x=x*10+ch-'0',ch=tc();
  21. }
  22. inline void add(int x,int y)
  23. {
  24. e[++cnt].to=y; e[cnt].next=head[x]; head[x]=cnt;
  25. }
  26. inline int min(int a,int b)
  27. {
  28. return a<b?a:b;
  29. }
  30. inline void Tarjan(int now)
  31. {
  32. dfn[now]=low[now]=++tot;
  33. stack[++top]=now; vis[now]=1;
  34. for (register int i=head[now];i!=-1;i=e[i].next)
  35. if (!dfn[e[i].to])
  36. {
  37. Tarjan(e[i].to);
  38. low[now]=min(low[now],low[e[i].to]);
  39. } else if (vis[e[i].to]) low[now]=min(low[now],dfn[e[i].to]);
  40. if (dfn[now]==low[now])
  41. {
  42. t[++sum]+=1; vis[now]=0;
  43. col[now]=sum;
  44. while (stack[top]!=now)
  45. {
  46. t[sum]+=1; vis[stack[top]]=0;
  47. col[stack[top--]]=sum;
  48. } --top;
  49. }
  50. }
  51. int main()
  52. {
  53. //freopen("CODE.in","r",stdin); freopen("CODE.out","w",stdout);
  54. register int i,j;
  55. memset(head,-1,sizeof(head));
  56. memset(e,-1,sizeof(e));
  57. read(n); read(m);
  58. for (i=1;i<=m;++i)
  59. read(x),read(y),add(x,y);
  60. for (i=1;i<=n;++i)
  61. if (!dfn[i]) Tarjan(i);
  62. for (i=1;i<=n;++i)
  63. for (j=head[i];j!=-1;j=e[j].next)
  64. if (col[i]!=col[e[j].to]) ++chu[col[i]];
  65. for (i=1;i<=sum;++i)
  66. if (!chu[i])
  67. {
  68. if (ans!=-1) { puts("0"); return 0; }
  69. ans=t[i];
  70. }
  71. printf("%d",ans);
  72. return 0;
  73. }

Luogu P2341 [HAOI2006]受欢迎的牛的更多相关文章

  1. [Luogu P2341] [HAOI2006]受欢迎的牛 (缩点+bitset)

    题面 传送门:https://www.luogu.org/problemnew/show/P2341 Solution 前排提示,本蒟蒻做法既奇葩又麻烦 我们先可以把题目转换一下. 可以把一头牛喜欢另 ...

  2. 【luogu P2341 [HAOI2006]受欢迎的牛】 题解

    题解报告:https://www.luogu.org/problemnew/show/P2341 我们把图中的强连通分量缩点,然后只有出度为0的牛是受欢迎的,这样如果出度为0的牛只有一个,说明受所有牛 ...

  3. Luogu P2341 [HAOI2006]受欢迎的牛 SCC缩点

    把强连通分量缩点,如果有且仅有一个出度为0的强连通分量,那么答案就是他的size:如果有多个入度为0的,那么没有明星牛. #include<cstdio> #include<iost ...

  4. 洛谷P2341 [HAOI2006]受欢迎的牛 (Tarjan,SCC缩点)

    P2341 [HAOI2006]受欢迎的牛|[模板]强连通分量 https://www.luogu.org/problem/P2341 题目描述 每头奶牛都梦想成为牛棚里的明星.被所有奶牛喜欢的奶牛就 ...

  5. 洛谷 P2341 [HAOI2006]受欢迎的牛 解题报告

    P2341 [HAOI2006]受欢迎的牛 题目描述 每头奶牛都梦想成为牛棚里的明星.被所有奶牛喜欢的奶牛就是一头明星奶牛.所有奶 牛都是自恋狂,每头奶牛总是喜欢自己的.奶牛之间的"喜欢&q ...

  6. [Luogu 2341] HAOI2006 受欢迎的牛

    [Luogu 2341] HAOI2006 受欢迎的牛 智能推的水题,一看是省选题就给做了,做一半才发现 Tarjan 算法忘干净了. Tarjan 求出SCC,算出每一个 SCC 包含原图的点数(s ...

  7. P2341 [HAOI2006]受欢迎的牛

    P2341 [HAOI2006]受欢迎的牛 塔尔羊标准模板(我才不会告诉你我嘴里含着一个九省联考的出题人) 不会劈配.林克卡特树.制胡窜 我还会叉粪宿主,梳妆素组,西安段素 #include<c ...

  8. P2341 [HAOI2006]受欢迎的牛(tarjan+缩点)

    P2341 [HAOI2006]受欢迎的牛 题目描述 每头奶牛都梦想成为牛棚里的明星.被所有奶牛喜欢的奶牛就是一头明星奶牛.所有奶 牛都是自恋狂,每头奶牛总是喜欢自己的.奶牛之间的“喜欢”是可以传递的 ...

  9. 洛谷——P2341 [HAOI2006]受欢迎的牛//POJ2186:Popular Cows

    P2341 [HAOI2006]受欢迎的牛/POJ2186:Popular Cows 题目背景 本题测试数据已修复. 题目描述 每头奶牛都梦想成为牛棚里的明星.被所有奶牛喜欢的奶牛就是一头明星奶牛.所 ...

随机推荐

  1. Android之使用枚举利弊及替代方案

    Android上不应该使用枚举,占内存,应该使用@XXXDef注解来替代 使用 Enum 的缺点 每一个枚举值都是一个对象,在使用它时会增加额外的内存消耗,所以枚举相比与 Integer 和 Stri ...

  2. Permission denied (publickey),Gitlab & Github 多ssh key 冲突 导致的权限问题

    Github 多ssh key导致的权限问题 :Permission denied (publickey) 公司用gitlib搭建了git服务器,自己已有github账号,用ssh-keygen分别生 ...

  3. Intellij IDEA去除@Autowired下划线红色提示

    Intellij IDEA通过@Autowired注入的对象,在不改变配置的情况下一直有红色下划线,虽然不影响运行,但是跟小Alan一样有强迫症的肯定受不鸟. 那么怎么去除它呢? 解决方式:改变@Au ...

  4. Maven入门详情

    Maven的作用 在开发中,为了保证编译通过,我们会到处去寻找jar包,当编译通过了,运行的时候,却发现"ClassNotFoundException",我们想到的是,难道还差ja ...

  5. 数据结构入门之链表(C语言实现)

    这篇文章主要是根据<数据结构与算法分析--C语言描述>一书的链表章节内容所写,该书作者给出了链表ADT的一些方法,但是并没有给出所有方法的实现.在学习的过程中将练习的代码记录在文章中,并添 ...

  6. innodb 表锁和行锁

    表锁  表锁相关结构: table->locks:数据字典table保存这个表上的所有表锁信息 trx->lock.table_locks:每个事务trx保存该事务所加的所有表锁信息 tr ...

  7. JavaScript、ES5、ES6的区别

    一.什么是JavaScript 1.JavaScript一种动态类型.弱类型.基于原型的客户端脚本语言,用来给HTML网页增加动态功能. 动态:在运行时确定数据类型.变量使用之前不需要类型声明,通常变 ...

  8. ecplice 中添加JavaFX插件学习

    fxml文件使用SceneBuilder打开报错 解决方法:Window-->Preferences-->JavaFX-->browse 路径是可执行的JavaFX Scene Bu ...

  9. kudu基础入门

    1.kudu介绍 1.1 背景介绍 在KUDU之前,大数据主要以两种方式存储: (1)静态数据: 以 HDFS 引擎作为存储引擎,适用于高吞吐量的离线大数据分析场景.这类存储的局限性是数据无法进行随机 ...

  10. SAP客户端 测试机、开发机、生产机

     SAP客户端 测试机.开发机.生产机     客户端(即Client),是SAP组织架构里最高层的组织单元,所有数据,包括静态数据(科目.客户.供应商.物料.资产等).业务数据(采购订单.销售订单. ...