题目描述

有n个城市,中间有单向道路连接,消息会沿着道路扩散,现在给出n个城市及其之间的道路,问至少需要在几个城市发布消息才能让这所有n个城市都得到消息。

输入格式

第一行两个整数n,m表示n个城市,m条单向道路。

以下m行,每行两个整数b,e表示有一条从b到e的道路,道路可以重复或存在自环。

输出格式

一行一个整数,表示至少要在几个城市中发布消息。

输入输出样例

输入 #1复制

输出 #1复制

说明/提示

【数据范围】

对于20%的数据,n≤200;

对于40%的数据,n≤2,000;

对于100%的数据,n≤100,000,m≤500,000.

【限制】

时间限制:1s,内存限制:256M

【注释】

样例中在4,5号城市中发布消息。

解析

这题比板子还简单。。。

板子好歹有个dp吧,这个判断个入度就完事了233。

参考代码

#include<cstdio>
#include<iostream>
#include<cmath>
#include<cstring>
#include<ctime>
#include<cstdlib>
#include<algorithm>
#include<queue>
#include<set>
#include<map>
#define N 500010
using namespace std;
inline int read()
{
int f=1,x=0;char c=getchar();
while(c<'0'||c>'9'){if(c=='-')f=-1;c=getchar();}
while(c>='0'&&c<='9'){x=x*10+c-'0';c=getchar();}
return x*f;
}
struct rec{
int next,ver;
}g[N],G[N];
int head[N],tot,headG[N],totG,idt,n,m;
int stack[N],top,dfn[N],low[N],cnt,ing[N],c[N];
bool ins[N];
inline void add(int x,int y)
{
g[++tot].ver=y;
g[tot].next=head[x],head[x]=tot;
}
inline void addG(int x,int y)
{
G[++totG].ver=y;
G[totG].next=headG[x],headG[x]=totG;
ing[y]++;
}
inline void tarjan(int x)
{
dfn[x]=low[x]=++cnt;
stack[++top]=x,ins[x]=1;
for(int i=head[x];i;i=g[i].next){
int y=g[i].ver;
if(!dfn[y]){
tarjan(y);
low[x]=min(low[x],low[y]);
}
else if(ins[y]) low[x]=min(dfn[y],low[x]);
}
if(dfn[x]==low[x]){
idt++;int y;
do{
y=stack[top--];ins[y]=0;
c[y]=idt;
}while(x!=y);
}
}
int main()
{
n=read(),m=read();
for(int i=1;i<=m;++i){
int u,v;
u=read(),v=read();
add(u,v);
}
for(int i=1;i<=n;++i)
if(!dfn[i]) tarjan(i);
for(int x=1;x<=n;++x)
for(int i=head[x];i;i=g[i].next){
int y=g[i].ver;
if(c[y]==c[x]) continue;
addG(c[x],c[y]);
}
int ans=0;
for(int i=1;i<=idt;++i)
if(ing[i]==0) ans++;
cout<<ans<<endl;
return 0;
}

最新文章

  1. .NET平台开源项目速览(3)小巧轻量级NoSQL文件数据库LiteDB
  2. @RenderBody、@RenderSection、@RenderPage、Html.RenderPartial、Html.RenderAction的作用和区别
  3. &lt;&lt;&lt; web里面Servlet高级应用的基础介绍
  4. zTree树的模糊搜索
  5. berkeley db replica机制 - 主从同步
  6. QT4/5中文乱码问题解决
  7. django关闭DEBUG后 static静态文件都访问不了
  8. 你所知道的Java单例模式并不是单例模式
  9. java 解决JFrame不能设置背景色的问题 分类: Java Game 2014-08-15 09:48 119人阅读 评论(0) 收藏
  10. Android内存管理(1)WRANGLING DALVIK: MEMORY MANAGEMENT IN ANDROID PART 1
  11. CSS 布局总结——变宽度布局
  12. 网上测试了很多关于PYTHON的WEBSOCKET样例,下面这个才成功了
  13. ios 改变状态栏颜色
  14. WPF - 如何引用external dll中图片
  15. Linux上夏时令的应对
  16. 负载,性能测试工具-Gatling
  17. Struts2的类型转换器
  18. Spring Boot 2 (六):使用 Docker 部署 Spring Boot 开源软件云收藏
  19. 55-56 ORM多表查询
  20. BZOJ4269:再见Xor(线性基)

热门文章

  1. Dotmemory 内存分析工具的操作手册
  2. socket编程(二)
  3. windows下大数据开发环境搭建(3)——Scala环境搭建
  4. [Oracle] - 使用 DBMS_UTILITY 查看异常详情
  5. 【并发】7、借助redis 实现多线程生产消费队列
  6. jdk8新特性--函数式接口的使用
  7. 百人研发团队的难题:研发管理、绩效考核、组织文化和OKR
  8. Codeforces Round #576 (Div. 1) 简要题解 (CDEF)
  9. Python之数据处理-2
  10. Python之Django