Luogu P2341 [HAOI2006]受欢迎的牛
这道题应该也是经典的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]受欢迎的牛相关推荐
- 【luogu P2341 [HAOI2006]受欢迎的牛】 题解
题解报告:https://www.luogu.org/problemnew/show/P2341 我们把图中的强连通分量缩点,然后只有出度为0的牛是受欢迎的,这样如果出度为0的牛只有一个,说明受所有牛 ...
- 洛谷P2341 [HAOI2006]受欢迎的牛 (Tarjan,SCC缩点)
P2341 [HAOI2006]受欢迎的牛|[模板]强连通分量 https://www.luogu.org/problem/P2341 题目描述 每头奶牛都梦想成为牛棚里的明星.被所有奶牛喜欢的奶牛就 ...
- 洛谷——P2341 [HAOI2006]受欢迎的牛//POJ2186:Popular Cows
P2341 [HAOI2006]受欢迎的牛/POJ2186:Popular Cows 题目背景 本题测试数据已修复. 题目描述 每头奶牛都梦想成为牛棚里的明星.被所有奶牛喜欢的奶牛就是一头明星奶牛.所 ...
- P2341 [HAOI2006]受欢迎的牛 强连通
题目背景 本题测试数据已修复. 题目描述 每头奶牛都梦想成为牛棚里的明星.被所有奶牛喜欢的奶牛就是一头明星奶牛.所有奶 牛都是自恋狂,每头奶牛总是喜欢自己的.奶牛之间的"喜欢"是可 ...
- 洛谷 P2341 [HAOI2006]受欢迎的牛
题目 题目背景 本题测试数据已修复. 题目描述 每头奶牛都梦想成为牛棚里的明星.被所有奶牛喜欢的奶牛就是一头明星奶牛.所有奶 牛都是自恋狂,每头奶牛总是喜欢自己的.奶牛之间的"喜欢" ...
- P2341 [HAOI2006]受欢迎的牛 (tarjan缩点+出度)
题意: 每头奶牛都梦想成为牛棚里的明星.被所有奶牛喜欢的奶牛就是一头明星奶牛.所有奶牛都是自恋狂,每头奶牛总是喜欢自己的.奶牛之间的"喜欢"是可以传递的--如果A喜欢B,B喜欢C, ...
- 【强连通】P2341 [USACO03FALL / HAOI2006] 受欢迎的牛 G
P2341 [USACO03FALL / HAOI2006] 受欢迎的牛 G 判断强连通的关键是dfn与low. dfn记录的是节点dfs搜索时的dfs序,而low则是记录表示这个点以及其子孙节点连的 ...
- BZOJ 1051: [HAOI2006]受欢迎的牛
1051: [HAOI2006]受欢迎的牛 Time Limit: 10 Sec Memory Limit: 162 MB Submit: 7120 Solved: 3779 [Submit][S ...
- bzoj1051: [HAOI2006]受欢迎的牛
tarjan缩点.判断是否只有一个没有出边.是则输出该点点数 #include<cstdio> #include<cstring> #include<iostream&g ...
最新文章
- ROS中Remap标签详解
- contentProvider中有关query方法的使用
- 非静态内部类中为什么不能拥有静态成员?
- c# 2.0 Factory的实现
- HDSF主要节点解说(二)工作原理
- Android GIS开发系列-- 入门季(5) FeatureLayer加载本地shp文件与要素查询
- MySql 存储大量长字节 Text报错处理办法
- 新手在前期应该怎样发“外链”(4)之终级外链法
- 《深入浅出WPF》学习笔记
- 虚拟机Centos系统安装
- 下拉框html回显,html option选中 回显 取值
- Log4j2 0day漏洞项目级紧急修复方法
- matlab去除图片水印_利用MATLAB去除图片中的水印
- Mirillis Action! v4.17.0 高清游戏视频录制软件
- 设置8211网口方法并关闭EEE模式
- 破解 --- apk文件解析
- 前端JavaScript(1) --Javascript简介,第一个JavaScript代码,数据类型,运算符,数据类型转换,流程控制,百度换肤,显示隐藏...
- 白钢条用什么可以切割_白钢用什么切割?
- 2021年山东省安全员C证新版试题及山东省安全员C证免费试题
- 格里高历日历判断闰年
热门文章
- java多个按钮监听,如何改成监听多个按钮啊用e.getsource()
- mysql数据库表空间最大值_mysql 数据库取最大值
- linux网络配置命令笔记,初学者学习linux笔记与练习-第二天。一些基本命令以及初级网络配置...
- mysql xa 和普通事务_一文看懂MySQL中基于XA实现的分布式事务
- 5.0安装没有costom mysql_Zabbix5.0监控mysql配置
- android分辨率对应关系,android各dpi与分辨率的对应关系
- python逻辑题_这道逻辑题 用 Python 代码 如何实现?
- eclipse占用内存过大_MySQL 服务占用cpu 100%,如何排查问题? (MySQL面试第七弹)...
- php数据库缓存服务器配置,php缓存技术(减少数据库服务器压力)
- php调mysql接口头文件_php基础系列:PHP连接MySQL数据库用到的三种API