首页 技术 正文
技术 2022年11月15日
0 收藏 914 点赞 2,161 浏览 684 个字

建反图,跑一个拓扑排序dp即可.

Code:

#include <bits/stdc++.h>
#define ll long long
#define N 100005
#define setIO(s) freopen(s".in","r",stdin)
using namespace std;
ll f[N];
queue<int>q;
int edges,n,m;
int in[N],out[N],hd[N],to[N<<1],nex[N<<1],mk[N];
void add(int u,int v)
{
nex[++edges]=hd[u],hd[u]=edges,to[edges]=v;
}
int main()
{
int i,j;
// setIO("input");
scanf("%d%d",&n,&m);
for(i=1;i<=m;++i)
{
int a,b;
scanf("%d%d",&a,&b),add(b,a),++in[a],++out[b];
}
for(i=1;i<=n;++i)
{
if(in[i]==0 && out[i]!=0)
{
q.push(i),f[i]=1,mk[i]=1;
}
}
for(;!q.empty();)
{
int u=q.front();q.pop();
for(int i=hd[u];i;i=nex[i])
{
int v=to[i];
f[v]+=f[u];
--in[v];
if(in[v]==0) q.push(v);
}
}
ll ans=0;
for(i=1;i<=n;++i)
{
if(out[i]==0 && !mk[i])
{
ans+=f[i];
}
}
printf("%lld\n",ans);
return 0;
}

  

相关推荐
python开发_常用的python模块及安装方法
adodb:我们领导推荐的数据库连接组件bsddb3:BerkeleyDB的连接组件Cheetah-1.0:我比较喜欢这个版本的cheeta…
日期:2022-11-24 点赞:878 阅读:8,943
Educational Codeforces Round 11 C. Hard Process 二分
C. Hard Process题目连接:http://www.codeforces.com/contest/660/problem/CDes…
日期:2022-11-24 点赞:807 阅读:5,469
下载Ubuntn 17.04 内核源代码
zengkefu@server1:/usr/src$ uname -aLinux server1 4.10.0-19-generic #21…
日期:2022-11-24 点赞:569 阅读:6,283
可用Active Desktop Calendar V7.86 注册码序列号
可用Active Desktop Calendar V7.86 注册码序列号Name: www.greendown.cn Code: &nb…
日期:2022-11-24 点赞:733 阅读:6,098
Android调用系统相机、自定义相机、处理大图片
Android调用系统相机和自定义相机实例本博文主要是介绍了android上使用相机进行拍照并显示的两种方式,并且由于涉及到要把拍到的照片显…
日期:2022-11-24 点赞:512 阅读:7,729
Struts的使用
一、Struts2的获取  Struts的官方网站为:http://struts.apache.org/  下载完Struts2的jar包,…
日期:2022-11-24 点赞:671 阅读:4,766