我正在学习使用Choco-solver。我发现它无法找到一个非常简单的问题的解决方案,这意味着我一定误解了一些东西......
我将我的代码简化为:
Model model = new Model("Minimum");
IntVar x = model.intVar("x", 1, 9, false);
IntVar y = model.intVar("y", 1, 9, false);
IntVar z = model.intVar("z", -1000, 1000, false);
z.eq(x.add(y.mul(2))).post();
Solver solver = model.getSolver();
solver.showStatistics();
solver.showSolutions();
solver.findSolution();
所以,三个整数变量和一个约束说z = x + 2y
. Choco-solver 回应Complete search - No solution
。
y.mul(2)
如果我将约束的内部部分从y.mul(1)
(x = 1, y = 1, z = 2) 或y.add(2)
(x = 1, y = 1, z = 4)更改,我发现我得到了正确的解决方案。我什至可以将其设置为y.mul(-2)
(x = 1 y = 9 z = -17),但如果我使用mul
大于 1 的整数,则约束似乎无法解决。
这里发生了什么?