Brief Solution:

强连通tarjan+压缩点+判断是否除了一个点,其它点都有出度

Detailed Solution:

把牛看成点
若一个点b能到达点a,则b认为a受欢迎
若所有的点都能到达点a,则a被所有的牛欢迎

对于某个强连通中的点,任意两点可互达,互相受欢迎
对图求强连通,并把强连通压缩成一个点
若点a向与点a不在同一个强连通集合的点b,则点a所在的集合指向点b所在的集合(边)

若一个强连通集合的点(新图的点A)能被所有的点到达,则新图所有的点能到达点A
此时新图没有环,若一个点A能被所有的点到达,则除了该点,其它点的出度都不为0(图必有没有出度的点,因为图没有环)
则能被所有的点到达的点只有一个,否则会有环,矛盾
(在没有环的条件下,图中所有的点到汇集(到达)该点)

Code:

 #include <stdio.h>
#include <stdlib.h>
#include <stdbool.h>
#include <malloc.h>
#define maxn 10000
#define maxm 50000 struct node
{
long d;
struct node *next;
}*info[maxn+];
long x[maxm+],y[maxm+];
long dfn[maxn+],low[maxn+],stack[maxn+],num[maxn+],ans[maxn+],count=,sum=;
bool vis[maxn+],vis_stack[maxn+],next[maxn+]; long min(long a,long b)
{
if (a>b)
return b;
else
return a;
} void tarjan(long d)
{
vis[d]=false;
count++;
stack[count]=d;
dfn[d]=count;
low[d]=count;
struct node *p;
long nd,pre;
p=info[d];
while (p)
{
nd=p->d;
if (vis[nd]==true)
{
tarjan(nd);
low[d]=min(low[d],low[nd]);
}
else if (vis_stack[nd]==true)
low[d]=min(low[d],dfn[nd]);
p=p->next;
}
pre=count;
if (dfn[d]==low[d])
{
sum++;
while (d!=stack[count])
{
num[stack[count]]=sum;
vis_stack[stack[count]]=false;
count--;
}
num[stack[count]]=sum;
vis_stack[stack[count]]=false;
count--;
ans[sum]=pre-count; //count+1~pre
}
} int main()
{
long i,n,m,d;
struct node *p;
scanf("%ld%ld",&n,&m);
// for (i=1;i<=n;i++)
// info[i]=NULL;
for (i=;i<=m;i++)
{
scanf("%ld%ld",&x[i],&y[i]);
p=(struct node *) malloc (sizeof(struct node));
p->d=y[i];
p->next=info[x[i]];
info[x[i]]=p;
}
for (i=;i<=n;i++)
{
vis[i]=true;
vis_stack[i]=true;
}
for (i=;i<=n;i++)
if (vis[i]==true)
tarjan(i);
for (i=;i<=sum;i++)
next[i]=false;
for (i=;i<=m;i++)
if (num[x[i]]!=num[y[i]])
next[num[x[i]]]=true;
d=;
for (i=;i<=sum;i++)
if (next[i]==false)
{
if (d==)
d=i;
else
{
d=-;
break;
}
}
if (d==-)
printf("0\n");
else
printf("%ld\n",ans[d]);
return ;
}

haoi2006_受欢迎的牛_Solution的更多相关文章

  1. bzoj1051 [HAOI2006]受欢迎的牛

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

  2. bzoj 1051 (强连通) 受欢迎的牛

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

  3. BZOJ 1051 最受欢迎的牛 解题报告

    题目直接摆在这里! 1051: [HAOI2006]受欢迎的牛 Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 4438  Solved: 2353[S ...

  4. 【BZOJ1051】1051: [HAOI2006]受欢迎的牛 tarjan求强连通分量+缩点

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

  5. 【bzoj1051】 [HAOI2006]受欢迎的牛 tarjan缩点判出度算点数

    [bzoj1051] [HAOI2006]受欢迎的牛 2014年1月8日7450 Description 每一头牛的愿望就是变成一头最受欢迎的牛.现在有N头牛,给你M对整数(A,B),表示牛A认为牛B ...

  6. 【BZOJ】1051: [HAOI2006]受欢迎的牛(tarjan)

    http://www.lydsy.com/JudgeOnline/problem.php?id=1051 这题还好-1A了..但是前提还是看了题解的 囧.....一开始认为是并查集,oh,不行,,无法 ...

  7. BZOJ 1051 受欢迎的牛(Tarjan缩点)

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

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

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

  9. 【HAOI2006】【BZOJ1051】【p1233】最受欢迎的牛

    BZOJ难得的水题(其实是HA太弱了) 原题: 每一头牛的愿望就是变成一头最受欢迎的牛.现在有N头牛,给你M对整数(A,B),表示牛A认为牛B受欢迎. 这 种关系是具有传递性的,如果A认为B受欢迎,B ...

随机推荐

  1. 字典学习(Dictionary Learning, KSVD)详解

    注:字典学习也是一种数据降维的方法,这里我用到SVD的知识,对SVD不太理解的地方,可以看看这篇博客:<SVD(奇异值分解)小结 >. 1.字典学习思想 字典学习的思想应该源来实际生活中的 ...

  2. Luogu P2483 【模板】k短路([SDOI2010]魔法猪学院)

    说实话,看到这道题的洛谷评级我傻了(传说中的最高难度) 然后看完题目才确定这真的是一道k短路的裸题. 也就敲了个A*吧,15分钟竟然没有调试一遍过. 欧洲玄学. 看题目,主要是找几条从1走到n的路加起 ...

  3. 一段程序的分析——C++析构器,何时析构

    最近在看小甲鱼的视频,有段程序是这么写的: #include <iostream> #include <string> class Pet { public: Pet(std: ...

  4. md5加密,同样的代码得到不同的加密结果(已解决)

    场景: 开发环境(windows下)调用第三方接口验签通过,发测试环境(linux下)后死活验签通过不了 原因: md5是一项成熟的加密技术,问题应该在代码里,查了查感觉可能是字符编码的问题,导致加签 ...

  5. R绘图 第八篇:绘制饼图(ggplot2)

    geom_bar()函数不仅可以绘制条形图,还能绘制饼图,跟绘制条形图的区别是坐标系不同,绘制饼图使用的坐标系polar,并且设置theta="y": coord_polar(th ...

  6. 迷你MVVM框架 avalonjs 0.8发布

    本版本最重要的特性是引进了AMD规范的模块加载器,亦即原来mass Framework 的并行加载器, 不同之处,它引进了requirejs的xxx!风格的插件机制,比如要延迟到DOM树建完时触发,是 ...

  7. ELK日志方案--使用Filebeat收集日志并输出到Kafka

    1,Filebeat简介 Filebeat是一个使用Go语言实现的轻量型日志采集器.在微服务体系中他与微服务部署在一起收集微服务产生的日志并推送到ELK. 在我们的架构设计中Kafka负责微服务和EL ...

  8. 20135202闫佳歆--week6 课本第三章学习笔记

    第三章 进程管理 一.进程 1.进程 进程就是处于执行期的程序. 进程就是正在执行的程序代码的实时结果. 进程是处于执行期的程序以及相关的资源的总称. 进程包括代码段和其他资源. 2.线程 执行线程, ...

  9. 20135220谈愈敏Blog5_系统调用(下)

    系统调用(下) 谈愈敏 原创作品转载请注明出处 <Linux内核分析>MOOC课程 http://mooc.study.163.com/course/USTC-1000029000 给Me ...

  10. 新手上路 git你好

    天哪,虽然我是一个学计算机的,但是我发现我的计算机学的真是……好吧不说了,言归正传.​ 这几天一直在着手于git,可能只是学了一个皮毛,结果也是不大尽人意,跟着别人学了学,鼓捣了鼓捣,还是有点小小的收 ...