1
0
This repository has been archived on 2025-03-06. You can view files and clone it, but cannot push or open issues or pull requests.
Jip J. Dekker fad1b07018 Squashed 'software/minizinc/' content from commit 4f10c8205
git-subtree-dir: software/minizinc
git-subtree-split: 4f10c82056ffcb1041d7ffef29d77a7eef92cf76
2021-06-16 14:06:46 +10:00

31 lines
792 B
MiniZinc

/***
!Test
expected: !Result
status: SATISFIED
solution: !Solution
x: [1, 3, 5, 7, 9]
y: [1, 3, 5, 8, 9]
***/
array[1..5] of var int: x :: add_to_output = [1,3,5,7,9];
array[4..8] of var int: y :: add_to_output = array1d(4..8, [1,3,5,8,9]);
constraint
let { int: lx = min(index_set(x)),
int: ux = max(index_set(x)),
int: ly = min(index_set(y)),
int: uy = max(index_set(y)),
int: size = max(ux - lx, uy - ly),
array[0..size+1] of var bool: b }
in
b[size+1] = (ux - lx < uy - ly) /\
forall (i in 0..size) (
b[i] = ((x[lx+i] < y[ly+i])
\/ ((x[lx+i] == y[ly+i]) /\ b[i+1]))
) /\ b[0];
solve satisfy;
output [
"x = ", show(x), ";\n",
"y = ", show(y), ";\n"
];