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

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

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

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

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

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

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

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

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

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

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

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

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

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

CODE

#include<cstdio>
#include<cstring>
using namespace std;
const int N=10005;
struct edge
{int to,next;
}e[N*5];
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;
bool vis[N];
inline char tc(void)
{static char fl[100000],*A=fl,*B=fl;return A==B&&(B=(A=fl)+fread(fl,1,100000,stdin),A==B)?EOF:*A++;
}
inline void read(int &x)
{x=0; char ch=tc();while (ch<'0'||ch>'9') ch=tc();while (ch>='0'&&ch<='9') x=x*10+ch-'0',ch=tc();
}
inline void add(int x,int y)
{e[++cnt].to=y; e[cnt].next=head[x]; head[x]=cnt;
}
inline int min(int a,int b)
{return a<b?a:b;
}
inline void Tarjan(int now)
{dfn[now]=low[now]=++tot;stack[++top]=now; vis[now]=1;for (register int i=head[now];i!=-1;i=e[i].next)if (!dfn[e[i].to]){Tarjan(e[i].to);low[now]=min(low[now],low[e[i].to]);} else if (vis[e[i].to]) low[now]=min(low[now],dfn[e[i].to]);if (dfn[now]==low[now]){t[++sum]+=1; vis[now]=0;col[now]=sum;while (stack[top]!=now){t[sum]+=1; vis[stack[top]]=0;col[stack[top--]]=sum;} --top;}
}
int main()
{//freopen("CODE.in","r",stdin); freopen("CODE.out","w",stdout);register int i,j;memset(head,-1,sizeof(head));memset(e,-1,sizeof(e));read(n); read(m);for (i=1;i<=m;++i)read(x),read(y),add(x,y);for (i=1;i<=n;++i)if (!dfn[i]) Tarjan(i);for (i=1;i<=n;++i)for (j=head[i];j!=-1;j=e[j].next)if (col[i]!=col[e[j].to]) ++chu[col[i]];for (i=1;i<=sum;++i)if (!chu[i]){if (ans!=-1) { puts("0"); return 0; }ans=t[i];}printf("%d",ans);return 0;
}

转载于:https://www.cnblogs.com/cjjsb/p/9037948.html

Luogu P2341 [HAOI2006]受欢迎的牛相关推荐

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

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

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

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

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

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

  4. P2341 [HAOI2006]受欢迎的牛 强连通

    题目背景 本题测试数据已修复. 题目描述 每头奶牛都梦想成为牛棚里的明星.被所有奶牛喜欢的奶牛就是一头明星奶牛.所有奶 牛都是自恋狂,每头奶牛总是喜欢自己的.奶牛之间的"喜欢"是可 ...

  5. 洛谷 P2341 [HAOI2006]受欢迎的牛

    题目 题目背景 本题测试数据已修复. 题目描述 每头奶牛都梦想成为牛棚里的明星.被所有奶牛喜欢的奶牛就是一头明星奶牛.所有奶 牛都是自恋狂,每头奶牛总是喜欢自己的.奶牛之间的"喜欢" ...

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

    题意: 每头奶牛都梦想成为牛棚里的明星.被所有奶牛喜欢的奶牛就是一头明星奶牛.所有奶牛都是自恋狂,每头奶牛总是喜欢自己的.奶牛之间的"喜欢"是可以传递的--如果A喜欢B,B喜欢C, ...

  7. 【强连通】P2341 [USACO03FALL / HAOI2006] 受欢迎的牛 G

    P2341 [USACO03FALL / HAOI2006] 受欢迎的牛 G 判断强连通的关键是dfn与low. dfn记录的是节点dfs搜索时的dfs序,而low则是记录表示这个点以及其子孙节点连的 ...

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

    1051: [HAOI2006]受欢迎的牛 Time Limit: 10 Sec  Memory Limit: 162 MB Submit: 7120  Solved: 3779 [Submit][S ...

  9. bzoj1051: [HAOI2006]受欢迎的牛

    tarjan缩点.判断是否只有一个没有出边.是则输出该点点数 #include<cstdio> #include<cstring> #include<iostream&g ...

最新文章

  1. ROS中Remap标签详解
  2. contentProvider中有关query方法的使用
  3. 非静态内部类中为什么不能拥有静态成员?
  4. c# 2.0 Factory的实现
  5. HDSF主要节点解说(二)工作原理
  6. Android GIS开发系列-- 入门季(5) FeatureLayer加载本地shp文件与要素查询
  7. MySql 存储大量长字节 Text报错处理办法
  8. 新手在前期应该怎样发“外链”(4)之终级外链法
  9. 《深入浅出WPF》学习笔记
  10. 虚拟机Centos系统安装
  11. 下拉框html回显,html option选中 回显 取值
  12. Log4j2 0day漏洞项目级紧急修复方法
  13. matlab去除图片水印_利用MATLAB去除图片中的水印
  14. Mirillis Action! v4.17.0 高清游戏视频录制软件
  15. 设置8211网口方法并关闭EEE模式
  16. 破解 --- apk文件解析
  17. 前端JavaScript(1) --Javascript简介,第一个JavaScript代码,数据类型,运算符,数据类型转换,流程控制,百度换肤,显示隐藏...
  18. 白钢条用什么可以切割_白钢用什么切割?
  19. 2021年山东省安全员C证新版试题及山东省安全员C证免费试题
  20. 格里高历日历判断闰年

热门文章

  1. java多个按钮监听,如何改成监听多个按钮啊用e.getsource()
  2. mysql数据库表空间最大值_mysql 数据库取最大值
  3. linux网络配置命令笔记,初学者学习linux笔记与练习-第二天。一些基本命令以及初级网络配置...
  4. mysql xa 和普通事务_一文看懂MySQL中基于XA实现的分布式事务
  5. 5.0安装没有costom mysql_Zabbix5.0监控mysql配置
  6. android分辨率对应关系,android各dpi与分辨率的对应关系
  7. python逻辑题_这道逻辑题 用 Python 代码 如何实现?
  8. eclipse占用内存过大_MySQL 服务占用cpu 100%,如何排查问题? (MySQL面试第七弹)...
  9. php数据库缓存服务器配置,php缓存技术(减少数据库服务器压力)
  10. php调mysql接口头文件_php基础系列:PHP连接MySQL数据库用到的三种API