如何在 Prolog 的列表中找到正数?
How to find the positive numbers in a list in Prolog?
我想在 prolog 中编写一个代码,获取一个列表并找到它的正数并将它们添加到一个新列表中,如下所示:
?- findPositives([-1,2,3,-5,-7,9],Result)
Result : [2,3,9]
我该如何编写这段代码?
使用tfilter/3
:
positive_truth(N, true) :-
N >= 0.
positive_truth(N, false) :-
N < 0.
?- tfilter(positive_truth, [-1,2,3,-5,-7,9],Result).
Result = [2,3,9]
或者,使用 library(clpfd)
:
pos_truth(Expr, Truth) :-
Expr #>= 0 #<==> Bool,
bool01_truth(Bool, Truth).
bool01_truth(0,false).
bool01_truth(1,true).
?- tfilter(pos_truth, [-1,2,3,-5,-7,9],Result).
Result = [2,3,9].
?- tfilter(pos_truth, [X,Y],Result).
Result = [], X in inf.. -1, Y in inf.. -1
; Result = [Y], X in inf.. -1, Y in 0..sup
; Result = [X], X in 0..sup, Y in inf.. -1
; Result = [X, Y], X in 0..sup, Y in 0..sup.
这将是简单的方法:
find_positives( Ns , Ps ) :- findall( X , ( member(X,Ns) , X > 0 ) , Ps ) .
但我怀疑您的导师希望您自己找出递归解决方案。因此...
find_positives( [] , [] ) .
find_positives( [N|Ns] , [P|Ps] ) :- N > 0 , find_positives(Ns,Ps) .
find_positives( [N|Ns] , Ps ) :- N =< 0 , find_positives(Ns,Ps) .
请注意,您可以通过引入确定性切割来保存比较,因此:
find_positives( [] , [] ) .
find_positives( [N|Ns] , [P|Ps] ) :- N > 0 , ! , find_positives(Ns,Ps) .
find_positives( [_|Ns] , Ps ) :- find_positives(Ns,Ps) .
并通过 'soft cut'/连词 (->/2
):
折叠第 2 和第 3 个子句,使其更加简洁
find_positives( [] , [] ) .
find_positives( [N|Ns] , R ) :-
( N > 0 -> R = [P|Ps]; R = Ps ) ,
find_positives(Ns,Ps) .
是否提高理解力由您决定。
我想在 prolog 中编写一个代码,获取一个列表并找到它的正数并将它们添加到一个新列表中,如下所示:
?- findPositives([-1,2,3,-5,-7,9],Result)
Result : [2,3,9]
我该如何编写这段代码?
使用tfilter/3
:
positive_truth(N, true) :-
N >= 0.
positive_truth(N, false) :-
N < 0.
?- tfilter(positive_truth, [-1,2,3,-5,-7,9],Result).
Result = [2,3,9]
或者,使用 library(clpfd)
:
pos_truth(Expr, Truth) :-
Expr #>= 0 #<==> Bool,
bool01_truth(Bool, Truth).
bool01_truth(0,false).
bool01_truth(1,true).
?- tfilter(pos_truth, [-1,2,3,-5,-7,9],Result).
Result = [2,3,9].
?- tfilter(pos_truth, [X,Y],Result).
Result = [], X in inf.. -1, Y in inf.. -1
; Result = [Y], X in inf.. -1, Y in 0..sup
; Result = [X], X in 0..sup, Y in inf.. -1
; Result = [X, Y], X in 0..sup, Y in 0..sup.
这将是简单的方法:
find_positives( Ns , Ps ) :- findall( X , ( member(X,Ns) , X > 0 ) , Ps ) .
但我怀疑您的导师希望您自己找出递归解决方案。因此...
find_positives( [] , [] ) .
find_positives( [N|Ns] , [P|Ps] ) :- N > 0 , find_positives(Ns,Ps) .
find_positives( [N|Ns] , Ps ) :- N =< 0 , find_positives(Ns,Ps) .
请注意,您可以通过引入确定性切割来保存比较,因此:
find_positives( [] , [] ) .
find_positives( [N|Ns] , [P|Ps] ) :- N > 0 , ! , find_positives(Ns,Ps) .
find_positives( [_|Ns] , Ps ) :- find_positives(Ns,Ps) .
并通过 'soft cut'/连词 (->/2
):
find_positives( [] , [] ) .
find_positives( [N|Ns] , R ) :-
( N > 0 -> R = [P|Ps]; R = Ps ) ,
find_positives(Ns,Ps) .
是否提高理解力由您决定。