差分约束系统

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了差分约束系统相关的知识,希望对你有一定的参考价值。

  网上的资料或多或少地缺乏一些完整性, 那么我也来一份缺乏完整性(大雾)的总结.

 

差分约束系统的概念

  设 $X = \left\{ x_1, x_2, ..., x_n \right\}$ .

  满足若干个形如 $x_i - x_j \ge w$ 的限制条件.

  解 $X$ .

 

  解一个问题有三个大的层次:

    ① 是否存在解? 构造任意一组解? 构造一组特殊解?

    ② 解的个数?

    ③ 解出所有?

  在我所能接触到的, 差分约束系统能完美地在多项式的时间复杂度内解决第一个层次, 而层次二和层次三就不行.

 

等价建图

  转化为图论的模型进行处理.

  对于任意的 $x_i$ , 设对应编号为 $i$ 的点.

  对于限制条件 $x_i - x_j \ge w$ , 连边 $i \rightarrow j$ , 边权为 $w$ .

 

解的存在性与构造任意一组解

  当图中存在负权回路时, 说明对于点 $i$ , 有 $w > 0, x_i - w \ge x_i$ , 所以一定无解.

  否则我们可以构造性地证明一定有解:

    令 $x_1, x_2, ..., x_n$ 的初始值为 $0$ .

    每次不断地选出一个点 $i$ , 枚举它的所有边 $(i, j, w)$ , 尝试进行松弛:

      如果 $x_i + w \ge x_j$ , 那么令 $x_j = x_i + w$ .

    如此迭代下去, 由于不存在负权回路, 所以一定会停止.

 

  我们发现这里的算法和最短路是等价的:

    对于判断负权回路, 可以用 SPFA 或 Floyd.

    对于迭代松弛, 可以用 SPFA 或 Floyd.

  所以直接用 SPFA 或者 Floyd 即可.

 

  总结一下, 我们解决了第一层次的两个小问题:

    (1) 解的存在性;

    (2) 构造任意一组解.

 

构造最大化 与某点差值 的解

  将问题再具体地描述一下:

    给定 $i$ , 构造 $\forall j, x_j - x_i$ 最大的解 $X$ .

  对于 $x_j < x_i$ , 最小化了差距 $|x_j - x_i|$ .

  对于 $x_j > x_i$ , 最大化了差距 $|x_j - x_i|$ .

 

  我们的做法是: 跑以 $i$ 为源点的单源最短路.

  因为对于任意的 $x_j$ , 在满足所有限制条件 "$\ge$" 下, 尽可能的大.

 

构造最小化 最大值与最小值的差距 的解

  构造 $\max_j x_j - \min_j x_j$ 最小的解.

 

  这里的做法就是构造性证明的做法.

  我们最初对 $x_1, x_2, ..., x_n$ 都赋成 $0$ .

  跑最短路下来, 对于 $x_i < 0$ , 其必然也尽可能的大.

  所以最小化的差距即为最终的 $\min_{j}(-x_j)$ .

以上是关于差分约束系统的主要内容,如果未能解决你的问题,请参考以下文章

差分约束系统

差分约束系统

差分约束模板

差分约束系统总结(转)

差分约束系统

差分约束系统--详讲