Prologを勉強しようとしています。私はこのスクリプトを見ました:
:- use_module(library(clpfd)).
puzzle([S,E,N,D] + [M,O,R,E] = [M,O,N,E,Y]) :-
Vars = [S,E,N,D,M,O,R,Y],
Vars ins 0..9,
all_different(Vars),
S*1000 + E*100 + N*10 + D + M*1000 + O*100 + R*10 + E #= M*10000 + O*1000 + N*100 + E*10 + Y,
M #\= 0,
S #\= 0.
ソース: https://github.com/Anniepoo/prolog-examples/blob/master/sendmoremoney.pl
私はそれをそのように実行し、いくつかの出力を取得します:
$ swipl -q -s sendmoremoney.pl
?- puzzle(X).
X = ([9, _G2009, _G2012, _G2015]+[1, 0, _G2024, _G2009]=[1, 0, _G2012, _G2009, _G2042]),
_G2009 in 4..7,
all_different([9, _G2009, _G2012, _G2015, 1, 0, _G2024, _G2042]),
91*_G2009+_G2015+10*_G2024#=90*_G2012+_G2042,
_G2012 in 5..8,
_G2015 in 2..8,
_G2024 in 2..8,
_G2042 in 2..8.
それは私に各文字の可能な値の範囲を与えているようです. しかし、各文字が可能な値の 1 つに割り当てられている単一のソリューションを取得するにはどうすればよいでしょうか? 非常に基本的な質問のように思えますが、理解できません。