LuoGu P2002 消息扩散

题目传送门
这个题其实就是tarjan缩点的板子题对吧....至少我是这么想的
首先这是个有向图,对于一个有向图,我们肯定要考虑环的存在与否,恰好这个题又是让我们找出最少的点,使得这几个点能够走遍全图
那么,显然,对于每一个强连通分量,我们看做一个点即可(因为强连通分量中每两个点之间一定能从一个点到另一个点,即从一个点出发一定能够走遍整个强连通分量)
缩完点之后,我们得到一个DAG,显然,对于每一个入度为零的点,我们都需要发布消息,其余入度不为零的点都可以通过这些入度为零的点走到
于是,这题就A了

#include <iostream>
#include <cstdlib>
#include <cstdio>using namespace std;const int N=1e5+5;
const int M=5e5+5;struct edge{int to,next;
}e[M];int n,m,dfn[N],low[N],cnt,head[N];
int idx[N],s[N],top,tot,sum;
bool ins[N];int ind[N],ans;inline void build(int u,int v){e[++tot].next=head[u];head[u]=tot;e[tot].to=v;return ;
}inline void tarjan(int cur){s[++top]=cur;ins[cur]=true;dfn[cur]=low[cur]=++cnt;for(int i=head[cur];i;i=e[i].next){int k=e[i].to;if(!dfn[k]){tarjan(k);low[cur]=min(low[cur],low[k]);}else if(ins[k]) low[cur]=min(low[cur],dfn[k]);}if(low[cur]==dfn[cur]){++sum;while(s[top+1]!=cur){idx[s[top]]=sum;ins[s[top--]]=false;}}return ;
}int main(){scanf("%d%d",&n,&m);for(int i=1;i<=m;++i){register int u,v;scanf("%d%d",&u,&v);build(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];j;j=e[j].next){int k=e[j].to;if(idx[i]!=idx[k]) ++ind[idx[k]];}for(int i=1;i<=sum;++i) if(!ind[i]) ++ans;printf("%d\n",ans);return 0;
}

转载于:https://www.cnblogs.com/Equinox-Flower/p/9648558.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/265998.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Controlling Execution

2019独角兽企业重金招聘Python工程师标准>>> 逗号操作符 逗号操作符在java中特殊之处在于两个地方&#xff1a; 1. 定义同种类型的变量时可以这样写&#xff1a; int i10,j20;//只有同种变量才行 2. 在for循环中的初始化条件和变化的步骤中对于同种类型的可以连接…

前端 js 非控件 使用标签打印机 打印二维码和文本_青岛Web前端(HTML5)面试题分享...

HTML5是前端开发人员必须掌握的技能之一&#xff0c;那么在面试时&#xff0c;面试官常问到的HTML5的问题有哪些呢&#xff1f;青岛HTML51、Doctype作用&#xff1f;严格模式与混杂模式如何区分&#xff1f;它们有何意义&#xff1f;答&#xff1a;告知浏览器的解析器&#xff…

SpringBoot整合SpringBatch实用简例

SpringBatch主要是一个轻量级的大数据量的并行处理(批处理)的框架。 作用和Hadoop很相似&#xff0c;不过Hadoop是基于重量级的分布式环境(处理巨量数据)&#xff0c;而SpringBatch是基于轻量的应用框架(处理中小数据)。 这里使用SpringBatch做了一个能跑的最简单例子&#xff…

安卓APP_ Fragment(1)—— Fragment概念、基础用法、动态变换、管理栈

摘自&#xff1a;安卓APP_ Fragment&#xff08;1&#xff09;—— Fragment概念、基础用法、动态变换、管理栈 作者&#xff1a;丶PURSUING 发布时间&#xff1a; 2021-04-15 23:32:31 网址&#xff1a;https://blog.csdn.net/weixin_44742824/article/details/115716359 目录…

谷歌五笔输入法电脑版_“五笔输入法”打字速度更快,为什么却没啥人用?

现如今&#xff0c;随着国内经济水平的不断发展&#xff0c;电脑和手机都已经不再是稀罕玩意&#xff0c;因为现在国内有很多的厂家都在生产手机和电脑&#xff0c;导致这些电子产品的价格下降&#xff0c;所以我们很轻易就能够买得起这样的产品。而在手机、电脑普及之后&#…

邮件系统磁盘监控脚本

#!/bin/shecho "邮件系统磁盘每周检测情况" >> /var/wangyang/checkdisk.txtuse"38.4G"var"819.2G"boot"160M"wang"/var/wangyang"cd $wangdf -h > /var/wangyang/disk.txt####根分区取值######warncat disk.txt |…

安卓APP_ Fragment(2)—— Activity与Fragment的通信

摘自&#xff1a;安卓APP_ Fragment&#xff08;2&#xff09;—— Activity与Fragment的通信 作者&#xff1a;丶PURSUING 发布时间&#xff1a; 2021-04-16 17:23:44 网址&#xff1a;https://blog.csdn.net/weixin_44742824/article/details/115743009 目录 Activity与Fragm…

常用python分析数据包pipinstallnumpy_安装numpy和matplotlib时,pip依赖关系解析失败

从一个干净的python2.7.3安装开始&#xff0c;如果我运行pip install -r requirements.txt包括以下内容要求.txt公司名称&#xff1a;^{pr2}$然后pip尝试在numpy之前安装matplotlib&#xff0c;但失败的原因是&#xff1a;BUILDING MATPLOTLIBmatplotlib: 1.2.1python: 2.7.3 (…

java socket 判断Socket连接失效

要判断socket连接链路是否可用时&#xff0c;不能通过socket.isClosed() 和 socket.isConnected() 方法判断&#xff0c;要通过心跳包 socket.sendUrgentData(0xFF) 。 当第一次连接成功后&#xff0c; socket.isClosed() false, socket.isConnected()true&#xff0c;只有在自…

MySQL存储过程权限检查主要点

一、权限相关&#xff1a;1.修改sql security Sql代码 ALTER PROCEDURE www SQL SECURITY INVOKER &#xff1b; ALTER PROCEDURE www SQL SECURITY DEFINER &#xff1b; &#xff08;1&#xff09;MySQL存储过程是通过指定SQL SECURITY子句指定执行存储过程的实际用户&…

安卓APP_ Fragment(3)—— Fragment的生命周期

摘自&#xff1a;安卓APP_ Fragment&#xff08;3&#xff09;—— Fragment的生命周期 作者&#xff1a;丶PURSUING 发布时间&#xff1a; 2021-04-16 22:32:12 网址&#xff1a;https://blog.csdn.net/weixin_44742824/article/details/115768202 目录 Fragment生命周期函数一…

BZOJ 1016--[JSOI2008]最小生成树计数(kruskal搜索)

1016: [JSOI2008]最小生成树计数 Time Limit: 1 Sec Memory Limit: 162 MBSubmit: 7429 Solved: 3098[Submit][Status][Discuss]Description 现在给出了一个简单无向加权图。你不满足于求出这个图的最小生成树&#xff0c;而希望知道这个图中有多少个不同的最小生成树。&…

python until语句_详解Lua中repeat...until循环语句的使用方法

与for和while循环不同&#xff0c;在循环的顶部测试循环条件&#xff0c;Lua编程语言的repeat...until 循环检查循环底部的状态。repeat...until 循环类似于while循环&#xff0c;不同的是do ... while循环是保证至少执行一次。语法Lua编程语言repeat...until循环的语法是&…

Javascript s08

AJAX ------------------------- AJAX 指异步 JavaScript 及 XML&#xff08;Asynchronous JavaScript And XML&#xff09;。 举例! 异步是发短信,同步是打电话. 异步的时候,会有回调. 想用JS去服务器拿数据? 客户端的JS.所以没有能力去服务器拿信息 借用服务端的PHP,JS模拟一…

linux驱动开发---并发控制

中断屏蔽 local_irq_disable();/* 临界代码*/local_irq_enable();2.原子操作 整形原子操作&#xff1a;void atomic_set(atomix_t *v,int i) //设置原子变量值为iatomic_t v ATOMIC_INIT(2); //设原子变量v值为2atomic_read(atomic_t *v);void atomic_add(int i,atomic_t *…

安卓APP_ 布局(8) —— 基于 RecyclerView 的 ViewPager2翻页

摘自&#xff1a;安卓APP_ 布局&#xff08;8) —— 基于 RecyclerView 的 ViewPager2翻页 作者&#xff1a;丶PURSUING 发布时间&#xff1a; 2021-04-20 15:37:54 网址&#xff1a;https://blog.csdn.net/weixin_44742824/article/details/115803077 viewpager2 是对Recycler…

Python基础—06-函数基础

函数基础 函数简介 定义&#xff1a;就是具有特定功能的一段代码优点&#xff1a; 解决代码的重复书写可以将功能的实现着和使用者分开&#xff0c;提高开发效率分类&#xff1a; 库函数&#xff1a;print、input、abs等自定义&#xff1a;用户自己封装的函数函数使用 定义函数…

python encode gbk_[转]Python UnicodeEncodeError: 'gbk' codec can't encode character 解决方法

使用Python写文件的时候&#xff0c;或者将网络数据流写入到本地文件的时候&#xff0c;大部分情况下会遇到&#xff1a;UnicodeEncodeError: gbk codec cant encode character \xa0 in position ... 这个问题。 网络上有很多类似的文件讲述如何解决这个问题&#xff0c;但是无…

iisnode默认不支持PUT和DELETE的解决

因为iisnode的自动重启服务器方便&#xff0c;一直用的它来作为开发中的node服务器&#xff0c;今天一个delete命令过去&#xff0c;得到一个405(?好像是&#xff09;错误&#xff0c;让我很郁闷。用原生的node试一下&#xff0c;是完美支持的&#xff0c;本来打算用Node算了的…

域名配置备忘录

几个国内yum镜像&#xff1a; http://mirrors.163.com/ //网易镜像 http://mirrors.aliyun.com/ //阿里镜像 http://centos.ustc.edu.cn/ //中科镜像 http://mirrors.sohu.com/ //搜狐镜像 yum 配置文件路径 . /etc/yum.repos.d/ 命令 yum clean all yum makecache