使用_时的额外输出

时间:2017-11-17 22:02:56

标签: prolog

我有以下代码:

pick_even([], []).
pick_even([_, H | T], [H | R]) :-
    pick_even(T, R).
pick_even([_, H , _ | T], [H | R]) :-
    pick_even(T, R).

运行查询?- pick_even(L,[4,7]).时,我想收到输出:

L = [_7650, 4, _7662, 7] ;
L = [_7650, 4, _7662, 7, _7674] ;

相反,我收到了一些我不想要的额外输出:

L = [_7650, 4, _7662, 7] ;
L = [_7650, 4, _7662, 7, _7674] ;
L = [_7650, 4, _7662, _7668, 7] ;
L = [_7650, 4, _7662, _7668, 7, _7680].

如何在不修改查询的情况下消除这些额外的输出?

我是prolog的新手,所以我希望这是一个非常简单的语法修复。

1 个答案:

答案 0 :(得分:5)

list_evens([], []).
list_evens([_|Es], Fs) :-
   list_evens2(Es, Fs).

list_evens2([], []).
list_evens2([E|Es], [E|Fs]) :-
   list_evens(Es, Fs).

也就是说,你特别忘记了单元素列表的情况。

而且,对于测试,最好的方法是采用最常见的查询

?- list_even(Xs, Ys).
   Xs = [],
   Ys = []
;  Xs = [_A],
   Ys = []
;  Xs = [_A,_B],
   Ys = [_B]
;  Xs = [_A,_B,_C],
   Ys = [_B]
;  Xs = [_A,_B,_C,_D],
   Ys = [_B,_D]
;  Xs = [_A,_B,_C,_D,_E],
   Ys = [_B,_D]
;  Xs = [_A,_B,_C,_D,_E,_F],
   Ys = [_B,_D,_F]
...

以这种方式你说:

  

哦,Prolog,我为什么要弄清楚哪些案例是有意义的?请为我做这个!

而且,勤奋地,Prolog将填补空白。所以你只需要确保你期望的所有答案都在这里。