我目前正在与prolog合作,并希望以证书方式将两个列表相乘.例如:
[1,2,3] and [4,5,6] are my two lists.
Run Code Online (Sandbox Code Playgroud)
我想要执行以下操作:
(1*4)+(2*5)+(3*6) = 32
Run Code Online (Sandbox Code Playgroud)
这样每个列表的第一个元素相互相乘,然后加上第二个元素相乘等.
这有可能进入Prolog吗?
我知道在其他语言中你可以做一个递归函数,带有列表的头部和尾部(其余的条目).这允许简单的乘法,但我不认为这是可能的prolog?
使用内置插件:
mult(X, Y, Z) :- Z is X * Y.
sum_prod(A, B, SumProd) :-
maplist(mult, A, B, Prods),
sumlist(Prods, SumProd). % In GNU Prolog this is sum_list
Run Code Online (Sandbox Code Playgroud)
使用简单的递归:
sum_prod([A|As], [B|Bs], SumProd) :-
sum_prod(As, Bs, SP),
SumProd is SP + A*B.
sum_prod([], [], 0).
Run Code Online (Sandbox Code Playgroud)
使用尾递归:
sum_prod(A, B, SumProd) :-
sum_prod(A, B, 0, SumProd).
sum_prod([A|As], [B|Bs], Acc, SumProd) :-
Acc1 is Acc + A*B,
sum_prod(As, Bs, Acc1, SumProd).
sum_prod([], [], Acc, Acc).
Run Code Online (Sandbox Code Playgroud)