1

所以在这里,对于我的数独项目,我有一个列表,例如:

L = [_G1-0:0:0,_G19-0:6:2,_G22-0:7:2,_G25-0:8:2].

我想过滤它以仅获取自由变量:

[_G1, _G19, _G22 and _G25].

所以想要那个,我写了这个谓词:

remove_position([], []) :- !.
remove_position([X-_|Xs], [X|Rs]) :- remove_position(Xs, Rs).

打电话时

?- remove_position(L, Result).

SWI-Prolog 答案

false.

所以我稍微编辑了谓词:

remove_position([], []) :- !.
remove_position([X-_:_:_|Xs], [X|Rs]) :- remove_position(Xs, Rs).

现在它按预期工作:

?- remove_position(L, Result).
Result = [_G1, _G19, _G22, _G25].

尽管如此,我还是看不出第一个有什么问题,对我来说,SWI-Prolog 应该将 0:0:0 与 _ 以及与 _:_:_ 匹配。有什么我没有得到的吗?或者它是一个 SWI-Prolog 错误?

感谢您的任何启发!

4

1 回答 1

4

当您有一个_G1-2:3:4没有任何括号的术语时,您必须考虑运算符的关联性和优先级,以了解如何解析该术语。

该术语与, not_G1-2:3:4相同,因此统一和失败。(_G1-2):(3:4)_G1-(2:3:4)_G1-2:3:4X-_

如果您在术语中添加括号,例如_G1-(2:3:4),那么您的原始remove_position/2谓词将起作用。

于 2011-11-23T11:28:38.440 回答