【WC2019笔记】模拟费用流算法

在一条数轴上,有 $n$ 只老鼠和 $m$ 个老鼠洞。

Q1

每只老鼠都只能往左走,求所有老鼠都进洞的最小代价(代价就是所有老鼠走的距离和)。

每个洞只能进一只老鼠。

A1

一开始陈江伦老师没说每个洞只能进一只老鼠,然后有个初中小同学上台装 $B$,说了每个洞不限老鼠的做法……(那不是弱智题么)

虽然现在这道题还是很简单,贪心或 $dp$ 都行。

($dp$ 的话,设 $f_{i,j}$ 表示前 $i$ 个老鼠和洞中,有 $j$ 个洞匹配了老鼠的最小代价)

Q2

问题同上,去掉老鼠只能往左走的限制。

A2

因为匹配不会相交(相交的匹配一定跟某个不相交的匹配等价

把老鼠往右走当做洞往左走。

 

$f_{i,j}$ 的 $j$ 可以为负数,表示还有 $-j$ 个老鼠需要匹配 $i$ 之后的洞。

如果 $i$ 为老鼠:$f_{i,j}=f_{i-1,j+1}+x_i\times [j\ge 0]-x_i\times [j\lt 0]$

如果 $i$ 为洞:$f_{i,j}=\min(f_{i-1,j},f_{i-1,j-1}+y_i\times [j\le 0]-y_i\times [j\gt 0]$

 

转载于:https://www.cnblogs.com/scx2015noip-as-php/p/10325568.html

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值