sup*_*o40 1 prolog constraint-programming eclipse-clp cryptarithmetic-puzzle instantiation-error
我在ECLiPSe下遇到了我的CSP问题.我想在我的密码中添加一个约束,要求TWO表示的数字可以被2整除.
[eclipse 11]: test(Xs).
instantiation fault in (_268{[1..4]}*100 + _200{[0..9]}*10 + _302{[0..9]}*1) mod 2#=0
Abort
Run Code Online (Sandbox Code Playgroud)
谢谢你的帮助.
我的代码:
/*
T W O
+ T H R E E
+ T H R E E
---------
E I G H T
*/
:- lib(fd).
myCsp(Xs):-
Xs=[W,I,G,H,T,R,O,E],
Xs::0..9,
[C1,C2,C3,C4]::0..2,
T #> 0,E #> 0,
O + E + E #= C1*10 + T,
W + E + E + C1 #= C2*10 + H,
T + R + R + C2 #= C3*10 + G,
H + H + C3 #= C4*10 + I,
T + T + C4 #= E,
(T*100 + W*10 + O*1) mod 2 #= 0,
alldifferent([W,I,G,H,T,R,O,E]).
test(Xs):-
myCsp(Xs),
labeling(Xs).
Run Code Online (Sandbox Code Playgroud)
mod/2操作
(T*100 + W*10 + O*1) mod 2 #= 0
Run Code Online (Sandbox Code Playgroud)
不受支持.您可以将该行重写为
T*100 + W*10 + O*1 #= 2*_
Run Code Online (Sandbox Code Playgroud)
这表示左侧表达式等于匿名整数变量的两倍,因此是两个的倍数.