洛谷4017 最大食物链计数

最大食物链计数

给你一个食物网,你要求出这个食物网中最大食物链的数量。

(这里的“最大食物链”,指的是生物学意义上的食物链,即最左端是不会捕食其他生物的生产者,最右端是不会被其他生物捕食的消费者。)

Delia 非常急,所以你只有 1 秒的时间。

由于这个结果可能过大,你只需要输出总数模上 80112002 的结果。

样例输入:

5 7
1 2
1 3
2 3
3 5
2 5
4 5
3 4

样例输出:

5

思路

虽然这道题算法标签就是拓扑排序,但我还是仔细思考了一下为什么不能用bfs做。

如果要用bfs做,解法就是找到起点(即入度为0的点)并沿着边不断拓展(就是普通bfs遍历整个图,只不过一个点可以到达多次),记录食物链的顶端被到达的次数即路径条数。但题目的数据规模很明显是不允许这种解法的。考虑一个最极端的情况:

在这里插入图片描述

那么bfs会拓展250000*250000次。。。

现在转入正题,用拓扑排序怎么解呢?

根据加法原理(我也不知道是不是,反正这样显得我很高大上),对于任意一个节点i来说,以它为终点的食物链条数等于所有能到达节点i的节点的食物链条数之和。设f[i]为以i为终点的食物链条数,即: f [ i ] = ∑ f [ p ] ( p 为 所 有 能 到 达 i 的 节 点 ) f[i]=\sum f[p](p为所有能到达i的节点) f[i]=f[p

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值