1
我在理解Prolog中的列表递归和修改时有点麻烦。我试图列出一个列表,然后在每个列表中,将列表中的每个元素与最后一个元素相乘。序言:列表递归和修改
这里是我的代码片段:
/*Find the last element of a list*/
lastelement(X,[X]).
lastelement(X,[_|L]) :- lastelement(X,L).
/*Multiply two lists together*/
multiplication(M1,M2,M1*M2).
/*Take a list, find the last element and multiply every part of that list by that element*/
/*Attach modified list to X*/
modifyL([],X) :- X is [].
modifyL([First|Tset],X) :- lastelement(Y,First),
multiplication(Y,First,MFirst),
modifyL([Tset],X),
append(X,MFirst,X).
当我尝试列出的任何名单,但是,我得到的是假的。有人可以给我任何指针 列表递归,这可能有助于进一步理解这个问题?
您使用哪个实现? – 2013-02-10 20:46:22
我目前使用SWI Prolog版本5.10 – 2013-02-10 20:47:52