我试图在不“破坏”列表的情况下找到最后一项(所有数字)。
我目前拥有的是这样的:
max([_|Xs]-Xs,R):-
Xs \= [],
max2(Xs,R),!.
max([X|Xs]-Xs,R):-
R = X.
max([]-[],99999).
Max2 是一个在普通列表中查找最后一项的函数:
max2([X],X):-
number(X),!.
max2([_|Xs],R):-
max2(Xs,R),!.
当我尝试使用一个项目的列表时,它可以工作 - 否则会失败:
max([22|X]-X,R)
R = 22
max([22,27|X]-X,R)
Stack limit (0.2Gb) exceeded
Stack sizes: local: 0.2Gb, global: 21Kb, trail: 3Kb
Stack depth: 1,560,328, last-call: 0%, Choice points: 1,560,312
Probable infinite recursion (cycle):
[1,560,328] max2([cyclic list], _1452)
[1,560,327] max2([cyclic list], _1484)
我尝试了其他方法,但是当我给它一个包含一个项目的列表时,它转换了它:
max([22|X]-X,R)
X = []
R = 22
所以我不能继续使用 X 作为自由变量。
我希望我写得很清楚。提前谢谢了。