题目传送门

这个题还是个缩点的板子题......

答案就是size大于1的强连通分量的个数

加一个size来统计就好了

  1. #include <iostream>
  2. #include <cstdlib>
  3. #include <cstdio>
  4. using namespace std;
  5. const int N=1e5+5;
  6. const int M=5e5+5;
  7. struct edge{
  8. int to,next;
  9. }e[M];
  10. int n,m,dfn[N],low[N],cnt,head[N];
  11. int idx[N],s[N],top,tot,sum,siz[N];
  12. bool ins[N];int ind[N],ans;
  13. inline void build(int u,int v){
  14. e[++tot].next=head[u];
  15. head[u]=tot;e[tot].to=v;
  16. return ;
  17. }
  18. inline void tarjan(int cur){
  19. s[++top]=cur;ins[cur]=true;
  20. dfn[cur]=low[cur]=++cnt;
  21. for(int i=head[cur];i;i=e[i].next){
  22. int k=e[i].to;
  23. if(!dfn[k]){
  24. tarjan(k);
  25. low[cur]=min(low[cur],low[k]);
  26. }else if(ins[k]) low[cur]=min(low[cur],dfn[k]);
  27. }
  28. if(low[cur]==dfn[cur]){
  29. register int ss=0;
  30. ++sum;
  31. while(s[top+1]!=cur){
  32. ++ss;
  33. idx[s[top]]=sum;
  34. ins[s[top--]]=false;
  35. }
  36. siz[sum]=ss;
  37. }
  38. return ;
  39. }
  40. int main(){
  41. scanf("%d%d",&n,&m);
  42. for(int i=1;i<=m;++i){
  43. register int u,v;
  44. scanf("%d%d",&u,&v);
  45. build(u,v);
  46. }
  47. for(int i=1;i<=n;++i) if(!dfn[i]) tarjan(i);
  48. for(int i=1;i<=n;++i)
  49. for(int j=head[i];j;j=e[j].next){
  50. int k=e[j].to;
  51. if(idx[i]!=idx[k]) ++ind[idx[k]];
  52. }
  53. for(int i=1;i<=sum;++i) if(!ind[i]&&siz[i]>1) ++ans;
  54. printf("%d\n",ans);
  55. return 0;
  56. }

LuoGu P2863 [USACO06JAN]牛的舞会The Cow Prom的更多相关文章

  1. luogu P2863 [USACO06JAN]牛的舞会The Cow Prom |Tarjan

    题目描述 The N (2 <= N <= 10,000) cows are so excited: it's prom night! They are dressed in their ...

  2. 【luogu P2863 [USACO06JAN]牛的舞会The Cow Prom】 题解

    题目链接:https://www.luogu.org/problemnew/show/P2863 求强连通分量大小>自己单个点的 #include <stack> #include ...

  3. bzoj1654 / P2863 [USACO06JAN]牛的舞会The Cow Prom

    P2863 [USACO06JAN]牛的舞会The Cow Prom 求点数$>1$的强连通分量数,裸的Tanjan模板. #include<iostream> #include&l ...

  4. P2863 [USACO06JAN]牛的舞会The Cow Prom

    洛谷——P2863 [USACO06JAN]牛的舞会The Cow Prom 题目描述 The N (2 <= N <= 10,000) cows are so excited: it's ...

  5. 洛谷——P2863 [USACO06JAN]牛的舞会The Cow Prom

    https://www.luogu.org/problem/show?pid=2863#sub 题目描述 The N (2 <= N <= 10,000) cows are so exci ...

  6. 洛谷 P2863 [USACO06JAN]牛的舞会The Cow Prom

    传送门 题目大意:形成一个环的牛可以跳舞,几个环连在一起是个小组,求几个小组. 题解:tarjian缩点后,求缩的点包含的原来的点数大于1的个数. 代码: #include<iostream&g ...

  7. 洛谷P2863 [USACO06JAN]牛的舞会The Cow Prom

    代码是粘的,庆幸我还能看懂. #include<iostream> #include<cstdio> #include<cmath> #include<alg ...

  8. 洛谷 P2863 [USACO06JAN]牛的舞会The Cow Prom 题解

    每日一题 day11 打卡 Analysis 好久没大Tarjan了,练习练习模板. 只要在Tarjan后扫一遍si数组看是否大于1就好了. #include<iostream> #inc ...

  9. 洛谷 P2863 [USACO06JAN]牛的舞会The Cow Prom(Tarjan)

    一道tarjan的模板水题 在这里还是着重解释一下tarjan的代码 #include<iostream> #include<cstdio> #include<algor ...

随机推荐

  1. Debian Security Advisory(Debian安全报告) DSA-4404-1 chromium

    Package : chromium CVE ID : CVE-2019-5786 Clement Lecigne在chromium的文件读取器实现中发现了一个use-after-free(释放后重用 ...

  2. 怎么从docker 内部去连接host 上的mysql

    一般来说数据最好放在一个公共的地方,这样在多个docker 可以共享这些数据. 这篇文章就是讲怎么从docker 内部去连接host上的 mysql 数据库. 因为我的host 有public ip, ...

  3. python的for循环、while循环

    1.for循环使用之乘法表 for i in range(1,10): for j in range(1,i+1): print('%s * %s = %s '%(j,i,i*j),end='') p ...

  4. Redis 集群环境的搭建

    下载与解压 [root@localhost ~]# cd /usr/temp/ [root@localhost temp]# wget http://download.redis.io/release ...

  5. Django学习手册 - 基于requests API验证(二)

    原理分析: API接口验证 1.一个认证的key server端 和 client端都必须有这么一个认证key. 2.认证登录的时间限定 3.保存已验证的信息,在以后的验证不能再次登录 client ...

  6. python-----短信、电话告警

    Twilio 1.访问http://twilio.com/并注册.注册了新账户后,你需要验证一个手机号码,短信将发给该号码. 2.Twilio 提供的试用账户包括一个电话号码,它将作为短信的发送者.你 ...

  7. Ettercap内网渗透

    最近网速很卡,于是想到有人在蹭网,怎么捉弄一下呢? 1.开启ettercap ettercap -G 2. Hosts->Scan,List 发现有几个新的地址192.168.1.71,192. ...

  8. [转] 浅谈Trie树(字典树)

    原文地址:https://www.cnblogs.com/TheRoadToTheGold/p/6290732.html Trie树(字典树) 一.引入 字典是干啥的?查找字的. 字典树自然也是起查找 ...

  9. Linxu基础知识:终端、终端模拟器、shell

    实验楼课程第二个实验的讲解部分出现了三个词,我不知道它们三个是什么关系.查阅了度娘,归纳如下: - 终端: 在UNIX/LINUX系统中,用户通过终端登录系统后得到一个Shell进程,这个终端就成为S ...

  10. matplotlib 直方图绘制详解

    n, bins, patches = plt.hist(datasets, bins, normed=False, facecolor=None, alpha=None) 函数说明 用于绘制多个数据集 ...