当前位置: 首页 > 编程日记 > 正文

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

P2341 [HAOI2006]受欢迎的牛/POJ2186:Popular Cows

题目背景

本题测试数据已修复。

题目描述

每头奶牛都梦想成为牛棚里的明星。被所有奶牛喜欢的奶牛就是一头明星奶牛。所有奶

牛都是自恋狂,每头奶牛总是喜欢自己的。奶牛之间的“喜欢”是可以传递的——如果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

解题报告:

题目大意:给定一个有向图,求有多少个顶点是由任何顶点出发都可达的。

有用的定理:有向无环图中唯一出度为0的点,一定可 以由任何点出发均可达(由于无环,所 以从任何点出发往前走,必然终止于 一个出度为0的点)

思路:tarjan缩点,判断强联通分量的出度为0即可,若出度为0的联通分量的个数>1,则这些点互相不可到达,原问题无解,反之输出联通分量里的点数即可。

#include<bits/stdc++.h>
#define N 100000using namespace std;void in(int &x){char c=getchar();x=0;int f=1;while(!isdigit(c)){if(c=='-') f=-1;c=getchar();}while(isdigit(c)){x=x*10+c-'0';c=getchar();}x*=f;
}struct node{int to,next;
}e[N];
int n,m,head[N],cnt,tot,dfn[N],low[N],item,belong[N],all[N],du[N];
stack<int>S;
bool vis[N];void add(int u,int v){e[++tot].to=v;e[tot].next=head[u];head[u]=tot;
}void tarjan(int u){dfn[u]=low[u]=++item;S.push(u);vis[u]=1;for(int i=head[u],v;i,v=e[i].to;i=e[i].next){if(!dfn[v]){tarjan(v);low[u]=min(low[v],low[u]);}else if(vis[v]){low[u]=min(low[u],dfn[v]);}}if(dfn[u]==low[u]){int v=u;++cnt;do{v=S.top();S.pop();vis[v]=false;belong[v]=cnt;all[cnt]++;}while(v!=u);}
}int main()
{in(n);in(m);for(int i=1;i<=m;i++){int u,v;in(u);in(v);add(u,v);}for(int i=1;i<=n;i++)if(!dfn[i]) tarjan(i);//记录出度for(int i=1;i<=n;i++){for(int j=head[i],v;j,v=e[j].to;j=e[j].next){if(belong[i]!=belong[v]){du[belong[i]]++;}}}int an=0;for(int i=1;i<=cnt;i++){if(!du[i]) {if(an) {puts("0");return 0;}an=i;}}printf("%d\n",all[an]);return 0;
}

转载于:https://www.cnblogs.com/song-/p/9545890.html

相关文章:

学习使用Bing Maps Silverlight Control(五):离线使用和自定义地图模式

6 离线使用 在笔记第一部分的时候就提到如果要使用Bing Maps Silverlight Control 进行开发&#xff0c;需要申请一个key&#xff0c;不让会显示一个错误提示出来。但是在实际开发或使用过程中&#xff0c;使用环境和地图数据可能不是在线的&#xff0c;但控件因为验证失败仍然…

python123第k序元素查找_Python实现折半查找并用matplotlib实现动态过程可视化

折半查找是算法中减治策略的基本例子&#xff0c;实现起来也很简单&#xff0c;但是在网上看到的图片教程不觉得很乾巴麽&#xff1f;&#xff1f;在这里插入图片描述这是一个简单的实现&#xff1a;def Reduction(lists, k):""":param lists: 元素列表:param k…

vim进阶技巧

本篇博文是在之前的《vim基础入门》的基础之上写的&#xff0c;不懂的同学可以先看之前的分享 1. 视觉范围的选择 普通模式下&#xff0c;按v键确定范围起点&#xff0c;然后移动光标&#xff0c;光标所在位置为范围的终点&#xff0c;然后按操作键完成其他操作&#xff0c;之…

Flex Air程序打包成独立的exe安装文件

2019独角兽企业重金招聘Python工程师标准>>> 开发背景&#xff1a; FlexBuilder3.2开发生成的Air程序需要能够独立安装&#xff0c;事先不需要安装AdobeAir运行环境 实现方法&#xff1a; 1)用winrar打开xx.air文件爱能&#xff0c;并将它解压在D:\airapp目录中。 2…

《C++primer》第一章--开始

之前开始读《Cprimer》&#xff0c;想着读书不动笔不如不读书&#xff0c;于是就想做一个读书笔记的内容&#xff0c;于是就想起了写一个《Cprimer读思录》的一个专栏。一是为了给自己平时读书做笔记&#xff0c;方便自己随时查看。二是为了督促自己每天学习。三是为了知识的分…

对于计算机网络的整体框架的概括(转载) 个人感觉很好

作者&#xff1a; 阮一峰 日期&#xff1a; 2012年5月31日 我们每天使用互联网&#xff0c;你是否想过&#xff0c;它是如何实现的&#xff1f; 全世界几十亿台电脑&#xff0c;连接在一起&#xff0c;两两通信。上海的某一块网卡送出信号&#xff0c;洛杉矶的另一块网卡居然就…

Centos修改系统语言

使用man page帮助时&#xff0c;发现居然是中文的&#xff0c;不过想想即便英语再水&#xff0c;也要逼着自己去适应。于是百度找了一下修改系统语言的方法。 首先使用 locale 命令查看当前的系统语言 然后修改时一般有两种方法&#xff0c;一是临时修改&#xff0c;立即生效&a…

tp3 普通模式url模式_Thinkphp 3.2.3 url 路由访问模式

Thinkphp 3.2.3 url 的4中路由模式&#xff1a;// 0 (普通模式)http://网址/index.php?m模块&c控制器&a方法http://localhost/index.php?mHome&cindex&aindex//1 (PATHINFO 模式) 默认为PATHINFO 模式http://网址/index.php/模块/控制器/方法http://localhos…

Mysql 基于 Amoeba 的 读写分离(2)

<?xml version"1.0" encoding"gbk"?> <!DOCTYPE amoeba:configuration SYSTEM "amoeba.dtd"> <amoeba:configuration xmlns:amoeba"http://amoeba.meidusa.com/"><proxy><!-- service class must implem…

Linux驱动之LCD驱动编写

在Linux驱动之内核自带的S3C2440的LCD驱动分析这篇博客中已经分析了编写LCD驱动的步骤&#xff0c;接下来就按照这个步骤来字尝试字节编写LCD驱动。用的LCD屏幕为tft屏&#xff0c;每个像素点为16bit。对应与红绿蓝分别为565。 1、分配一个fb_info结构 2、设置fb_info结构 3、硬…

《C++primer》第二章--变量和基本内置类型

基本内置类型 如何选择类型的几点建议 当明确知晓数值不能为负数时&#xff0c;选用无符号类型使用int进行整数运算。因为short一般表示的范围比较小&#xff0c;而long一般和int有相同的范围。如果表示的范围超过了int就使用long long算术运算时尽量不要使用char和bool&…

【入门】等差素数组

题目描述 如果两个素数之和的一半仍然是一个素数&#xff0c;则这三个素数可以组成一个等差素数组&#xff0c;如&#xff08;37&#xff09;/25&#xff0c;则&#xff08;3&#xff0c;5&#xff0c;7&#xff09;为一个等差素数组&#xff0c;编程求100以内的所有等差素数组…

flutter和webapp_Flutter全平台!迁移现有Flutter项目到WEB端

写在前面Flutter 是 Google推出并开源的移动应用开发框架&#xff0c;主打跨平台、高保真、高性能。开发者可以通过 Dart语言开发 App&#xff0c;一套代码同时运行在 iOS 、Android、web和桌面端。Flutter_web是Flutter代码兼容web的实现&#xff0c;可以将使用Dart编写的现有…

使用正则表达式构造定制的HTML5输入框

为什么80%的码农都做不了架构师&#xff1f;>>> 正则表达式&#xff08;点此在线编辑测试&#xff09;是一个功能强大的灵活而简洁的匹配文本字符串的工具&#xff0c;比如匹配特定的字符、单词等。正则表达式通过一个语言规则来书写&#xff0c;通过正则表达式处理…

idea dubbo jar error:cvc-complex-type.2.4.c: 通配符的匹配很全面, 但无法找到元素 'dubbo:application' 的声明...

声明&#xff1a; 出现这个错误的情形是&#xff0c;在idea开发环境里面运行是没有问题的&#xff0c;使用哦idea自带的打包工具生成jar之后&#xff0c;运行jar的时候报的这个错误&#xff0c;如果不是这个情况&#xff0c;这篇文章可能不适用。 主要的原因是spring.schemas、…

lwip可以用于发udp_LWIPUDP一对多

最近在STM32F767的开发板上移植了LWIP UDP的代码&#xff0c;开发板的资料里面有介绍LWIP移植的文档&#xff0c;介绍了几种网络通信方式&#xff0c;如TCP server&#xff0c;TCP client&#xff0c;UDP&#xff0c;按照文档里面的介绍也很容易实现。这里我选择的是基于ucos2操…

奇淫怪巧之给Delphi的PrintDialog增加一个页码选定范围打印的Edit

在Delphi中使用PrintDialog打印对话框的时候&#xff0c;这个控件有三个选项&#xff0c;就是PrintRang那个属性的三个选项&#xff0c;其中有一个选项三&#xff0c;让我们自定义选择页码范围来打印。但是比较蛋疼的是&#xff0c;这个地方选中了之后啥子效果都没有。无法制定…

进程管理(图文)

进程的图文形象表示 阮一峰–进程与线程的一个简单解释 多进程实质 现在&#xff0c;多核CPU已经非常普及了&#xff0c;但是&#xff0c;即使过去的单核CPU&#xff0c;也可以执行多任务。由于CPU执行代码都是顺序执行的&#xff0c;那么&#xff0c;单核CPU是怎么执行多任…

拿到WP官方主题Twenty Ten就是一顿nofollow伺候

2019独角兽企业重金招聘Python工程师标准>>> 今天2012-07-03&#xff0c;我的个人cn域名申请下来了&#xff0c;于是网站搬迁&#xff0c;暂时没有选择一个好的WordPress主题&#xff0c;只有用默认的Twenty Ten&#xff0c;不过这个主题对SEO方面还有一些欠缺&…

Qt分析:Qt中的两种定时器

QTimer类的定时器 QTimer类定时器是QObject类定时器的扩展版或者说升级版&#xff0c;因为它可以提供更多的功能。比如说&#xff0c;它支持单次触发和多次触发。 使用QTimer类定时器的步骤&#xff1a; &#xff08;1&#xff09;创建一个QTimer定时器实例&#xff1a;QTimer …

uestc 1012 饭卡

饭卡(card) Time Limit: 1000 ms Memory Limit: 65535 kB Solved: 253 Tried: 2169 Submit Status Best Solution Back Description 电子科大本部食堂的饭卡有一种很诡异的设计&#xff0c;即在购买之前判断余额。如果购买一个商品之前&#xff0c;卡上的剩余金额大于或等…

wps临时文件不自动删除_win10系统下wps残留文件无法删除如何解决

一位用户反馈自己在win10系统电脑中卸载金山WPS办公软件时&#xff0c;发现根本无法将wps残留的文件夹删除&#xff0c;在删除的时候提示“操作无法完成&#xff0c;因为其中的文件夹或文件已在另一程序打开 请关闭该文件夹文件重试”&#xff0c;这该怎么办呢&#xff1f;接下…

WEB登录H3C模拟器

思路&#xff1a;先将路由器与本地网卡绑定&#xff0c;然后将本地网卡与路由器接口ip设置在同一网段&#xff0c;在路由器上建立本地用户&#xff0c;最后登录就OK了。 1、查看本机网卡的序列号&#xff0c;在CMD里输入systeminfo&#xff0c;输出的最下…

ArcMap 通过DEM获取高程值

第一种方法&#xff1a;Extract values to Points工具&#xff0c;这个网上的资料比较多&#xff0c;就不介绍了。 第二种方法&#xff1a;Interpolate Shape工具 直接用Arc Toolbox->3D Analyst Tools->功能性表面->Interpolate Shape工具就行&#xff0c;可以将DEM的…

Linux进程描述符task_struct结构体简析

进程是处于执行期的程序以及它所管理的资源&#xff08;如打开的文件、挂起的信号、进程状态、地址空间等等&#xff09;的总称 Linux内核通过一个被称为进程描述符的task_struct结构体来管理进程&#xff0c;这个结构体包含了一个进程所需的所有信息。它定义在include/linux/…

hdu 1312 Red and Black 解题报告

题目链接&#xff1a;http://acm.hdu.edu.cn/showproblem.php?pid1312 第二条深搜&#xff0c;题目并不难&#xff0c;但是做了我好久好久&#xff0c;由于一个细节&#xff0c;让我赌上了一个晚上的时间。 题目大意&#xff1a;从图中的标记开始&#xff0c;向四个相邻的方向…

easyexcel怎么设置表头宽度_easyexcel 自动设置列宽

com.alibabaeasyexcel2.1.4导出controller层代码RequestMapping("/download")public void download(HttpServletResponse response) throws IOException {response.setContentType("application/vnd.ms-excel");response.setCharacterEncoding("utf-8…

php ImageMagick扩展

linux下安装php ImageMagick扩展模块下载ImageMagick源码包&#xff1a;#wget ftp://ftp.u-aizu.ac.jp/pub/graphics/p_w_picpath/ImageMagick/p_w_picpathmagick.org/ImageMagick.tar.gz 编译安装&#xff1a;#tar -zxvf ImageMagick.tar.gz #cd ImageMagick-xxxx-0#./confi…

调用浏览器的打印方法打印页面内容

2018-08-30 直接调用浏览器的打印方法 1、打印按钮 <a href"#" target"_self" οnclick"printme()">打印</a> 2、js //打印function printme() {$.messager.confirm(确认, 确认打印&#xff1f;, function (r) {if (r) {document.bo…

jsp中九大内置对象

内置组件 JSP共有以下9种基本内置组件&#xff08;可与ASP的6种内部组件相对应&#xff09;&#xff1a;1.request对象 客户端的请求信息被封装在request对象中&#xff0c;通过它才能了解到客户的需求&#xff0c;然后做出响应。它是HttpServletRequest类的实例。序号 方 法 说…