2020-09-29 11:53:15 +02:00
|
|
|
predicate fzn_all_different_int(array [int] of var int: x);
|
2012-09-03 18:26:36 +00:00
|
|
|
predicate count(array [int] of var int: x, var int: y, var int: c);
|
2020-09-29 11:53:15 +02:00
|
|
|
predicate fixed_fzn_cumulative(array [int] of var int: s, array [int] of int: d, array [int] of int: r, int: b);
|
2012-09-03 18:26:36 +00:00
|
|
|
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);
|
2020-09-29 11:53:15 +02:00
|
|
|
predicate var_fzn_cumulative(array [int] of var int: s, array [int] of int: d, array [int] of int: r, var int: b);
|
2012-09-03 18:26:36 +00:00
|
|
|
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];
|
2020-09-29 11:53:15 +02:00
|
|
|
constraint fzn_all_different_int(letters);
|
2012-09-03 18:26:36 +00:00
|
|
|
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;
|