HAOI2006 (洛谷P2341)受欢迎的牛 题解
HAOI2006 (洛谷P2341)受欢迎的牛 题解
题目描述
友情链接原题
每头奶牛都梦想成为牛棚里的明星。被所有奶牛喜欢的奶牛就是一头明星奶牛。所有奶
牛都是自恋狂,每头奶牛总是喜欢自己的。奶牛之间的“喜欢”是可以传递的——如果A喜
欢B,B喜欢C,那么A也喜欢C。牛栏里共有N 头奶牛,给定一些奶牛之间的爱慕关系,请你
算出有多少头奶牛可以当明星。
输入输出格式
输入格式:
第一行:两个用空格分开的整数:N和M
第二行到第M + 1行:每行两个用空格分开的整数:A和B,表示A喜欢B
输出格式:
第一行:单独一个整数,表示明星奶牛的数量
输入输出样例
输入样例#1:
3 3
1 2
2 1
2 3
输出样例#1:
1
说明
只有 3 号奶牛可以做明星
【数据范围】
10%的数据N<=20, M<=50
30%的数据N<=1000,M<=20000
70%的数据N<=5000,M<=50000
100%的数据N<=10000,M<=50000
题目分析
这是一道强连通分量的题
首先把样例拿来画一下(解决图论题目常规操作),得到如下的图:

我们可以发现一号和二号可以构成一个强连通分量,然后就会想到tarjan缩点。。把一号和二号缩点后,可以得到如下的图:

我们推论:缩点后出度为零的点为明星牛(假如出度为零的点是一个强连通分量的缩点,那么这个强连通分量中的所有牛都是明星牛)这个其实很好证,假如明星牛的出度不为0,它就会和其他点构成一个强连通分量,那么就是缩点不彻底,而我们讨论的是完全缩点后的情况。
我们在举一个例子

缩点后的图是这样的

这两个点都是出度为0,但是我们发现并没有明星牛。原因是有两个点出度为零。所以推论应该改为:缩点后唯一的出度为0的点是明星牛,这样也可以避免掉单独的点带来的影响。
假如这整个图就是一个强连通图,那么每一头牛都是明星牛(缩点后只有一个点,仍然满足推论)。
然后这个题就简单了,算是裸的tarjan。
附上标程
#include<bits/stdc++.h>
#define maxn 1000000
using namespace std;
int Next[maxn],a=0,F[maxn],Head[maxn];
int cmpi[maxn],out[maxn],E[maxn],cmp[maxn],s[maxn];
int dfn[maxn],low[maxn],top=0,cmpid=0,tim=0;
bool V[maxn],D[maxn];
void ins(int x,int y,int i)
{
E[i]=y;
Next[i]=Head[x];
Head[x]=i;
}//链式前向星
int find()
{
int ans=0;
for(int i=1;i<=a;i++)
{
for(int p=Head[F[i]];p;p=Next[p])//列举这个点的所有邻接点
{
if(!D[E[p]])ans++;//如果这个点的邻接点不和他在一个强联通分量的话,那么我们就发现他所在的分量有了出度
}
}
return ans;
}//找一组强连通分量的出度
void tarjan(int u)
{
dfn[u]=low[u]=++tim;
s[++top]=u;
V[u]=true;
for(int p=Head[u];p;p=Next[p])
{
int y=E[p];
if(!dfn[y])
{
tarjan(y);
low[u]=min(low[y],low[u]);
}
else
{
if(V[y])low[u]=min(low[u],dfn[y]);
}
}
if(dfn[u]==low[u])
{
int y;
cmpid++;
do
{
y=s[top--];
V[y]=false;
F[++a]=y;//将这个点存入暂时数组
D[y]=true;
cmpi[cmpid]++;
}while(y!=u);
cmp[cmpid]=find();//cmp存储他的出度
a=0;
memset(D,false,sizeof(D));//D数组表示这个点在不在这个强连通分量
}
}
int main()
{
int n,m;
scanf("%d%d",&n,&m);
for(int i=1;i<=m;i++)
{
int a,b;
scanf("%d%d",&a,&b);
ins(a,b,i);
}
for(int i=1;i<=n;i++)
if(!dfn[i])tarjan(i);
int c=0,ans;
for(int i=1;i<=cmpid;i++)
if(!cmp[i])c++,ans=i;//检查图是否连通
if(c==1)printf("%d",cmpi[ans]);//输出
else printf("0");
return 0;
}
HAOI2006 (洛谷P2341)受欢迎的牛 题解的更多相关文章
- 洛谷P2341受欢迎的牛
传送门啦 这是一个tarjan强连通分量与出度结合的例题. 先明确一下题意,如果这个点(缩点之后的)没有出度,这个点才能成为明星牛(明星牛的定义是:所有牛都喜欢他才可以). 由于我们进行了缩点,所以我 ...
- 洛谷 [P2341] 受欢迎的牛
强连通分量 一个结论: 在有向图中, 一个联通块能被所有点遍历当且仅当图中只有一个连通块出度为零 #include <iostream> #include <cstdio> # ...
- 【题解】洛谷P2341 [HAOI2006]受欢迎的牛(强连通分量)
洛谷P2341:https://www.luogu.org/problemnew/show/P2341 前言 这题看错题目 足足花了将近5小时提交了15次 在一位dalao的提醒下才AC了 记得要看清 ...
- 洛谷P1854 花店橱窗布置 分析+题解代码
洛谷P1854 花店橱窗布置 分析+题解代码 蒟蒻的第一道提高+/省选-,纪念一下. 题目描述: 某花店现有F束花,每一束花的品种都不一样,同时至少有同样数量的花瓶,被按顺序摆成一行,花瓶的位置是固定 ...
- 洛谷P3412 仓鼠找$Sugar\ II$题解(期望+统计论?)
洛谷P3412 仓鼠找\(Sugar\ II\)题解(期望+统计论?) 标签:题解 阅读体验:https://zybuluo.com/Junlier/note/1327573 原题链接:洛谷P3412 ...
- 洛谷P3502 [POI2010]CHO-Hamsters感想及题解(图论+字符串+矩阵加速$dp\&Floyd$)
洛谷P3502 [POI2010]CHO-Hamsters感想及题解(图论+字符串+矩阵加速\(dp\&Floyd\)) 标签:题解 阅读体验:https://zybuluo.com/Junl ...
- 洛谷 P2341 [HAOI2006]受欢迎的牛 解题报告
P2341 [HAOI2006]受欢迎的牛 题目描述 每头奶牛都梦想成为牛棚里的明星.被所有奶牛喜欢的奶牛就是一头明星奶牛.所有奶 牛都是自恋狂,每头奶牛总是喜欢自己的.奶牛之间的"喜欢&q ...
- 洛谷——P2341 [HAOI2006]受欢迎的牛//POJ2186:Popular Cows
P2341 [HAOI2006]受欢迎的牛/POJ2186:Popular Cows 题目背景 本题测试数据已修复. 题目描述 每头奶牛都梦想成为牛棚里的明星.被所有奶牛喜欢的奶牛就是一头明星奶牛.所 ...
- 洛谷P2341 [HAOI2006]受欢迎的牛 (Tarjan,SCC缩点)
P2341 [HAOI2006]受欢迎的牛|[模板]强连通分量 https://www.luogu.org/problem/P2341 题目描述 每头奶牛都梦想成为牛棚里的明星.被所有奶牛喜欢的奶牛就 ...
随机推荐
- cookbook_元编程
1给函数添加一个包装 问题:给函数加一个外包装层,已添加额外的处理,例如,记录日志,计时统计等 解决方案:可以定义一个装饰器来包装函数 2编写装饰器时如何保存函数的元数据 问题:当一个函数被装饰器装饰 ...
- DFS_全球变暖_蓝桥杯2018省赛N0.9
你有一张某海域NxN像素的照片,"."表示海洋."#"表示陆地,如下所示: ....... .##.... .##.... ....##. ..####. .. ...
- Android的简述3
Activity的生命周期 Activity类中有许多onXXX形式的函数可以重载,比如onCreate,onStart,onStop,onPause,那么它们的调用顺序到底是如何的呢?下面就通过一个 ...
- IO流总结2
2.字节流 |-- InputStream(读) |-- OutputStream(写) 由于字节是二进制数据,所以字节流可以操作任何类型的数据,值得注意的是字符流使用的是字符数组char[]而字节流 ...
- tomcat配置启动文件
修改tomcat到指定文件夹 conf -> server.xml <Host name="localhost" appBase="webapps" ...
- Thinkphp5.0快速入门笔记(1)
学习来源与说明 https://www.kancloud.cn/thinkphp/thinkphp5_quickstart 测试与部署均在windows10下进行学习. Composer安装和更新 C ...
- 四、Python基础(1)
目录 四.Python基础(1) 四.Python基础(1) 1.什么是变量? 一种变化的量,量是记录世界上的状态,变指得是这些状态是会变化的. 2.为什么有变量? 因为计算机程序的运行就是一系列状态 ...
- Java----面向对象(继承&多态)
一.继承 什么是继承 ? 让类与类之间产生了子父类关系 ; 继承的好处是: 提高代码的复用性和维护性 java中继承的特点是: 只支持单继承.不支持多继承,但是可以多层继承; 四种权限修饰符是 : p ...
- 简单聊聊红黑树(Red Black Tree)
前言 众所周知,红黑树是非常经典,也很非常重要的数据结构,自从1972年被发明以来,因为其稳定高效的特性,40多年的时间里,红黑树一直应用在许多系统组件和基础类库中,默默无闻的为我们提供服务,身边 ...
- restapi(3)- MongoDBEngine : MongoDB Scala编程工具库
最近刚好有同事在学习MongoDB,我们讨论过MongoDB应该置于服务器端然后通过web-service为客户端提供数据的上传下载服务.我们可以用上节讨论的respapi框架来实现针对MongoDB ...