首页 > 代码库 > 差分约束系统总结(转)
差分约束系统总结(转)
转载地址
差分约束总结:
今天请教了DQS大神,算是对差分做一个系统性的总结吧,也算是对自己近期不完善理解的差分约束理一遍。
差分约束分为3大类,求最小,求最大,求是否满足约束条件,第三类求是否满足直接判断负环即可,一般都结合前两类来出题。
1:求最小。求最小一般是跑最长路,在已有约束条件下建立超级原点(自以为是这么叫),然后根据题目向每一条边建边(边权根据题目而定),然后跑最长路,求最小的一般是满足这样的约束条件:a >= b + c(这么写是为了体现最长路的性质,便于理解)(并且注意这里不要和松弛混了,这个式子说明a要比b至少大c,所以b要通向a至少要c,可以这么理解一下),满足这样的约束条件就b向a建一条权值为c的边。
2:求最大。求最大一般是跑最短路,同样是在已有约束条件下建立超级原点,建边,最短路类型的一般是满足约束条件:a <= b + c(体现了最短路的性质),这样的约束条件下由b向a建一条权值为c的边。
但是题目可能不给你恰好的约束条件(a >= b + c || a <= b + c),可能会出现下面的情况:
a < b + c
a > b + c
a = b + c
a < b
a > b
a = b;
依次转化为下面情况:
a <= b + c - 1
a >= b + c + 1
(a >= b + c a <= b + c)
另外三种是上面三种在C = 0时的情况;
其他自行脑补~ 当然具体情况依题目而定咯~
题目链接:
POJ:Candies;
BZOJ: [SCOI2011]糖果 题号居然是2330 不是权限题
今天T3 =-= 没有链接
差分约束系统总结(转)
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。