洛谷P3573 [POI2014]RAJ-Rally(BZOJ3832)

该博客探讨了如何解决洛谷P3573和BZOJ3832这两个图论问题,主要涉及拓扑排序和堆的应用。通过一次拓扑排序,计算从起点到各节点及从各节点到终点的最长路径,并利用堆来高效地处理最长路径的更新和查询操作。
摘要由CSDN通过智能技术生成

拓扑排序 堆

洛谷题目传送门
BZOJ题目传送门

妙蛙

注意到这是一个DAG,那么我们可以一遍拓排求出从起点到 i i i为最长路 d s [ i ] ds[i] ds[i] i i i到终点的最长路 d t [ i ] dt[i] dt[i](s向所有入度为0的点连边,所有出度为0的点向t连边)。若一条最长路 l l l经过 ( u , v ) (u,v) (u,v),那么必有 l = d s [ u ] + d t [ v ] + 1 l=ds[u]+dt[v]+1 l=ds[u]+dt[v]+1

我们按照拓扑序枚举每个点。每次把关于它的最长路从 t t t集删掉并更新答案,然后把它们加到 s s s集里。因此要维护的就是三个操作:删除一个数,插入一个数和查询最大值。用堆即可。

代码:

#include<queue>
#include
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值