【BZOJ1051】[HAOI2006]受欢迎的牛

题面

bzoj

洛谷

题解

假如\(A\)喜欢\(B\)就连一条\(A\)到\(B\)的边

然后缩点,如果图不连通就\(Impossible\)

否则输出出度为\(0\)的环的大小

  1. #include<iostream>
  2. #include<cstdio>
  3. #include<cstdlib>
  4. #include<cstring>
  5. #include<cmath>
  6. #include<algorithm>
  7. using namespace std;
  8. inline int gi(){
  9. register int data=0, w = 1;
  10. register char ch=0;
  11. while (ch != '-' && (ch > '9' || ch < '0')) ch = getchar();
  12. if (ch == '-') w = -1 , ch = getchar();
  13. while (ch >= '0' && ch <= '9') data = (data << 1) + (data << 3) + (ch ^ 48), ch = getchar();
  14. return w * data;
  15. }
  16. #define MAX_N 10005
  17. #define MAX_M 50005
  18. struct Edge {
  19. int to, next;
  20. } e[MAX_M];
  21. int h[MAX_N], cnt;
  22. int n, m;
  23. void Add_Edge(int u, int v) {
  24. e[cnt].to = v, e[cnt].next = h[u], h[u] = cnt++;
  25. }
  26. int tim = 0, num = 0, top = 0;
  27. int low[MAX_N], dfn[MAX_N], color[MAX_N], st[MAX_N];
  28. int tot[MAX_N];
  29. void tarjan(int x) {
  30. low[x] = dfn[x] = ++tim;
  31. st[++top] = x;
  32. for (register int i = h[x]; ~i; i = e[i].next) {
  33. if (!dfn[e[i].to]) {
  34. tarjan(e[i].to);
  35. low[x] = min(low[x], low[e[i].to]);
  36. } else if (!color[e[i].to])
  37. low[x] = min(low[x], dfn[e[i].to]);
  38. }
  39. if (low[x] == dfn[x]) {
  40. color[x] = ++num;
  41. tot[num]++;
  42. while (st[top] != x) {
  43. color[st[top]] = num;
  44. tot[num]++;
  45. --top;
  46. }
  47. --top;
  48. }
  49. }
  50. int d[MAX_N];
  51. int main () {
  52. memset(h, -1, sizeof(h));
  53. n = gi(), m = gi();
  54. for (register int i = 1; i <= m; i++) {
  55. int u = gi(), v = gi();
  56. Add_Edge(u, v);
  57. }
  58. for (register int i = 1; i <= n; i++)
  59. if (!dfn[i]) tarjan(i);
  60. int ans = 0, F = 0;
  61. for (register int x = 1; x <= n; x++)
  62. for (int i = h[x]; ~i; i = e[i].next)
  63. if (color[x] != color[e[i].to]) d[color[x]]++;
  64. for (register int i = 1; i <= num; i++) {
  65. if (d[i] == 0) F++, ans = tot[i];
  66. }
  67. if (F == 1) printf("%d\n", ans);
  68. else printf("0\n");
  69. return 0;
  70. }

【BZOJ1051】[HAOI2006]受欢迎的牛的更多相关文章

  1. bzoj1051 [HAOI2006]受欢迎的牛

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

  2. bzoj1051: [HAOI2006]受欢迎的牛(tarjan板子)

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

  3. [BZOJ1051][HAOI2006] 受欢迎的牛 tarjan求联通分量

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

  4. [Bzoj1051][HAOI2006]受欢迎的牛(缩环)

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

  5. bzoj1051: [HAOI2006]受欢迎的牛(强联通)

    1051: [HAOI2006]受欢迎的牛 题目:传送门 题解: 今天又做一道水题... 强联通啊很明显 水个模板之后统计一下每个强联通分量中点的个数,再统计一下出度... 不难发现:缩点之后当且仅当 ...

  6. [bzoj1051] [HAOI2006]受欢迎的牛 (Tarjan+缩点)

    强连通图,缩点 Description 每一头牛的愿望就是变成一头最受欢迎的牛.现在有N头牛,给你M对整数(A,B),表示牛A认为牛B受欢迎. 这 种关系是具有传递性的,如果A认为B受欢迎,B认为C受 ...

  7. [BZOJ1051] [HAOI2006] 受欢迎的牛 (强联通分量)

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

  8. 【强连通分量】Bzoj1051 HAOI2006 受欢迎的牛

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

  9. BZOJ1051 [HAOI2006]受欢迎的牛 Tarjan 强连通缩点

    欢迎访问~原文出处——博客园-zhouzhendong 去博客园看该题解 题目传送门 - BZOJ1051 题意概括 有n只牛,有m个羡慕关系. 羡慕关系具有传递性. 如果A羡慕B,B羡慕C,那么我们 ...

  10. bzoj1051 [HAOI2006]受欢迎的牛 tarjan&&缩点

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

随机推荐

  1. Jquery 保留N位小数,且千位以上用","号隔开

    s:数据Value n:保留小数位数 function jinEFmoney(s, n) { if (s == '' || s == null) return '0.00'; n = n > 0 ...

  2. iframe内联框

    内联框中表格的下划线老是显示不出来,设置宽度百分比不起作用,调整了文本域的宽度也不行.只能动态调整iframe的高度.

  3. 适配iOS6与iOS7

    适配屏幕其实很简单,但为了保持兼容性以及写的代码的通用性,以及最小的改动代码,本人按照如下的一种方式来适配,可以一劳永逸. 1. 先定义几个宏,分辨表示应用可以使用区域的高度,屏幕可用区域的高度,屏幕 ...

  4. Celery学习---Celery 分布式队列介绍及安装

    Celery介绍和基本使用 Celery 是一个 基于python开发的分布式异步消息任务队列,通过它可以轻松的实现任务的异步处理, 如果你的业务场景中需要用到异步任务,就可以考虑使用celery, ...

  5. PHP解决网站大数据大流量与高并发

    1:硬件方面 普通的一个p4的服务器每天最多能支持10万左右的IP,如果访问量超过10W那么需要专用的服务器才能解决,如果硬件不给力软件怎么优化都是于事无补的.主要影响服务器的速度 有:网络-硬盘读写 ...

  6. SpringBoot @AutoWired Null

    在调用工具类时,若工具类中含有@Autowired注解,这此工具类对象必须同样使用@Autowired注解,否则工具类中的Spring注入的对象都为空值,这里的HadoopTest就是这样 比如MyC ...

  7. HBase HA的分布式集群部署(适合3、5节点)

    本博文的主要内容有: .HBase的分布模式(3.5节点)安装    .HBase的分布模式(3.5节点)的启动 .HBase HA的分布式集群的安装 .HBase HA的分布式集群的启动    .H ...

  8. (1)I/O流 (2)线程

    1.I/O流1.1 ObjectOutputStream类(重点)(1)基本概念 java.io.ObjectOutputStream类主要用于将Java对象整体写入到输出流中. 只能将支持 java ...

  9. 复用$.ajax方式传递参数错误处理

    1.封装后的方法,在 data:inData 传递参数的方式和一般不一样,如果不注意会出现错误. function getDataByJsonP(methName, inData, fn) { $.a ...

  10. 微信小程序 置顶/取消置顶

    wxml <view wx:for="{{confirmlist}}" wx:for-item="confirm" wx:for-index=" ...