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).

但是,当我尝试任何列表时,我得到的都是错误的。有人可以给我任何关于列表递归的指示,以帮助进一步理解这个问题吗?

4

1 回答 1

1
modifyL([],X) :- X is [].

这不是你想的那样,用来得到算术评估的结果。

你可以写

 modifyL([],X) :- X = [].

或者干脆

 modifyL([],[]).

当您使用列表时,您对该列表的每个元素重复相同的过程,您可以使用专为此设计的 maplist。模板是 maplist(Goal, L1 L2)。

modify(L1, L2) :-
  maplist(multiply_one_list,L1, L2).

multiply_one_list 与列表一起使用,您可以这样写:

multiply_one_list(L_in, L_out) :-
  % getting last argument
  reverse(L_in, [Last | _]),
  % multiply each element of the list by
  % the last element, one more maplist !
  maplist(multiply_one_element(Last), L_in, L_out).

multiply_one_element(Last, In, Out) :-
  Out is In * Last.
于 2013-02-10T21:34:30.373 回答