我正在尝试编写一个程序来解决一般的密码难题,例如 AM+PM=DAY, SEND+MORE=MONEY..
我写的程序是:
gsolve([H1,T1],[H2|T2],[H3|T3]):-
gsolvehelper([H1,T1],[H2|T2],[H3|T3],[0,1,2,3,4,5,6,7,8,9],0).
gsolvehelper([H1,T1],[H2|T2],[H3|T3],D,C):-
( var(H1)->select(H1,D,D1);D1=D),
( var(H2)->select(H2,D1,D2);D2=D1),
( X1 is H1+H2+C),
( H3 is mod(X1,10)),
( C1 is X1//10),
gsolvehelper(T1,T2,T3,D2,C1).
输入的形式为:
gsolve([A,M],[P,M],[D,A,Y]).
将前两个列表的头部添加到进位中以找到第三个列表的头部和新的进位,依此类推。
我得到的错误是:
ERROR: is/2: Type error: `[]' expected, found `[2,_G3922]' ("x" must hold one character)
我无法弄清楚这个错误是什么。有人可以帮我吗?