enigma_planets.fzn 2.2 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45
predicate all_different_int(array [int] of var int: x);
predicate count(array [int] of var int: x, var int: y, var int: c);
predicate fixed_cumulative(array [int] of var int: s, array [int] of int: d, array [int] of int: r, int: b);
predicate global_cardinality(array [int] of var int: x, array [int] of int: cover, array [int] of var int: counts);
predicate maximum_int(var int: m, array [int] of var int: x);
predicate minimum_int(var int: m, array [int] of var int: x);
predicate sliding_sum(int: low, int: up, int: seq, array [int] of var int: vs);
predicate sort(array [int] of var int: x, array [int] of var int: y);
predicate table_bool(array [int] of var bool: x, array [int, int] of bool: t);
predicate table_int(array [int] of var int: x, array [int, int] of int: t);
predicate var_cumulative(array [int] of var int: s, array [int] of int: d, array [int] of int: r, var int: b);
var 7..182: INT____00001 :: is_defined_var :: var_is_introduced;
var 1..26: a;
var 1..26: c;
var 1..26: e;
var 1..26: h;
var 1..26: i;
var 1..26: j;
var 1..26: l;
var 1..26: m;
var 1..26: n;
var 1..26: o;
var 1..26: p;
var 7..182: planets :: output_var = INT____00001;
var 1..26: r;
var 1..26: s;
var 1..26: t;
var 1..26: u;
var 1..26: v;
var 1..26: y;
array [1..17] of var 1..26: letters :: output_array([1..17]) = [p, l, u, t, o, r, a, n, s, e, i, m, j, h, v, c, y];
constraint all_different_int(letters);
constraint int_lin_eq([1, 1, 1], [n, s, u], 18);
constraint int_lin_eq([1, 1, 2], [m, n, o], 36);
constraint int_lin_eq([1, 1, 1, 1], [a, m, r, s], 32);
constraint int_lin_eq([1, 1, 1, 1, 1], [a, e, h, r, t], 31);
constraint int_lin_eq([1, 1, 1, 1, 1], [e, n, s, u, v], 39);
constraint int_lin_eq([1, 1, 1, 1, 1], [l, o, p, t, u], 40);
constraint int_lin_eq([1, 1, 1, 1, 2], [a, n, r, s, u], 36);
constraint int_lin_eq([2, 2, 1, 1, 1], [e, n, p, t, u], 29);
constraint int_lin_eq([1, 1, 1, 1, 1, 1], [a, n, r, s, t, u], 33);
constraint int_lin_eq([1, 1, 1, 2, 1, 1], [c, e, m, r, u, y], 33);
constraint int_lin_eq([1, 1, 1, 1, 1, 1, 1], [e, i, j, p, r, t, u], 50);
constraint int_lin_eq([-1, 1, 1, 1, 1, 1, 1, 1], [INT____00001, a, e, l, n, p, s, t], 0) :: defines_var(INT____00001);
solve  :: int_search(letters, first_fail, indomain, complete) satisfy;