POJ 2135 Farm Tour

47 篇文章 0 订阅

求从点i到点j,再从点j到点i的最短路程,其中每条无向边只能走一次

 

如果考虑无向环会很复杂,根据分类,这道题用费用流做,把边上距离看成是费用,然后考虑怎么构图

 

从点j走到点i的边,反向之后就是从i走到j了,于是等于从i到j走两次,这样,建立一个源点,到起点的容量为2,费用为0,表示从起点走两次,建立一个汇点,点N到汇点的容量为2,费用为0,表示到达N点两次,每天边上的容量为1,表示只能走一次,这样就把整个题目意思表示出来了

 

注意可能有重边,用邻接表储存边

 

这道题简单地求两次最短路径是不行的,由于一条边只能走一次的限制,分别求两次的最短距离加起来不一定是最短的

 

代码:

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值