[首页]
[文章]
[教程]
首页
Web开发
Windows开发
编程语言
数据库技术
移动平台
系统服务
微信
设计
布布扣
其他
数据分析
首页
>
其他
> 详细
对于差分约束系统的一些理解
时间:
2015-08-08 15:00:34
阅读:
229
评论:
0
收藏:
0
[点我收藏+]
【1】最短路如何建图?
差分约束系统是{di-dj<=u}的集合,
考虑将di-dj<=u变形为dj+u>=di,
∴结点i要满足所有的结点j的dj+u>=di,
那么必须至少取到min(dj+u),如果取得更大,就会矛盾。
于是这样就可以建最短路,求出一组取值。
【2】这组取值有什么意义?
它通过最短路得到。
刚好满足了所有条件,约束得最紧密。
也就是说,它不唯一,任意的di可能可以更小,相对差就会变大。
【2】这组取值的一个性质:可以平移
简略的证明:∵dj+u>=di,设dj‘=dj+a,∴dj+a+u>=di+a即dj‘+u>=di‘.
【3】松弛操作次数上限为n-1。
描述性证明:最短路径最多有n-1条边。迭代松弛操作,实际上就是按顶点距离s的层次,逐层生成这棵最短路径树的过程,最短路径树最多n-1层。
【4】结点初始取值
设虚拟结点0,从0到任意结点i连一条边,设其权值为0,然后做最短路。
现在问题来了:为什么这样是成立的?
上网找什么资料都不讲究正确性,直接给出做法。
现在其实是多给了n组d0+0>=di的不等式,要证明 加了这么多组和没加这些 的解的存在性不受改变。
∵出现矛盾只能是出现了负权回路。
∴即证明通过加了0结点出现了负权回路。
由于0只连出去,不连回来,∴负权回路上必然没有0结点。
∴假如现在有负权回路,那么原来一定也有负权回路。
不过注意,加了0的限制条件,所得到的解就不一定是最优解了。
例如,对于差分约束系统d1-d2>=-3。
首先建立结点1,2,建边(1,2,3)。
然后建立结点0,连接(0,1,0),(0,2,0)。
求出的值d1=d2=0。
【5】如何求出一组最小正整数解(非负整数解,etc.)
每个联通块是互相约束的。
先用并查集求联通块,然后每块平移。
版权声明:本文为博主原创文章,未经博主允许不得转载。
对于差分约束系统的一些理解
原文:http://blog.csdn.net/u013598409/article/details/47357933
踩
(
0
)
赞
(
0
)
举报
评论
一句话评论(
0
)
登录后才能评论!
分享档案
更多>
2021年09月23日 (328)
2021年09月24日 (313)
2021年09月17日 (191)
2021年09月15日 (369)
2021年09月16日 (411)
2021年09月13日 (439)
2021年09月11日 (398)
2021年09月12日 (393)
2021年09月10日 (160)
2021年09月08日 (222)
最新文章
更多>
2021/09/28 scripts
2022-05-27
vue自定义全局指令v-emoji限制input输入表情和特殊字符
2022-05-27
9.26学习总结
2022-05-27
vim操作
2022-05-27
深入理解计算机基础 第三章
2022-05-27
C++ string 作为形参与引用传递(转)
2022-05-27
python 加解密
2022-05-27
JavaScript-对象数组里根据id获取name,对象可能有children属性
2022-05-27
SQL语句——保持现有内容在后面增加内容
2022-05-27
virsh命令文档
2022-05-27
教程昨日排行
更多>
1.
list.reverse()
2.
Django Admin 管理工具
3.
AppML 案例模型
4.
HTML 标签列表(功能排序)
5.
HTML 颜色名
6.
HTML 语言代码
7.
jQuery 事件
8.
jEasyUI 创建分割按钮
9.
jEasyUI 创建复杂布局
10.
jEasyUI 创建简单窗口
友情链接
汇智网
PHP教程
插件网
关于我们
-
联系我们
-
留言反馈
- 联系我们:wmxa8@hotmail.com
© 2014
bubuko.com
版权所有
打开技术之扣,分享程序人生!