我有一个列表列表,我需要找到其中最长的一个。如果有多个长度相同,则返回的相同。谢谢。
问问题
6489 次
6 回答
8
这是一个通用谓词,它扫描列表以查找由给定目标定义的单个成员。
select_element(Goal, [Head | Tail], Selected) :-
select_element(Goal, Tail, Head, Selected).
select_element(_Goal, [], Selected, Selected).
select_element(Goal, [Head | Tail], Current, FinalSelected) :-
call(Goal, Head, Current, Selected),
select_element(Goal, Tail, Selected, FinalSelected).
假设您定义了一个谓词
get_bigger_number(N1, N2, N) :-
N is max(N1, N2).
现在您可以执行:
?- select_element(get_bigger_number, [5, 1, -2, 10, 3.2, 0], Selected).
Selected = 10
所以你现在需要做的就是定义一个谓词get_longer_list(L1, L2, L)
,并使用它来代替get_bigger_number/3
.
当然,使用一般谓词 likeselect_element/3
可能不是很有效。例如,您应该尽量避免多次计算同一个列表的长度,因为这种计算在 Prolog 中很慢(至少如果在 Prolog 中以标准方式实现)。
于 2009-11-02T11:34:35.827 回答
3
请考虑我的方法。
longest([L], L) :-
!.
longest([H|T], H) :-
length(H, N),
longest(T, X),
length(X, M),
N > M,
!.
longest([H|T], X) :-
longest(T, X),
!.
然后你可以咨询它:
?- longest([[1]], N).
N = [1] ;
?- longest([[1],[2]], N).
N = [2] .
?- longest([[1],[2], [3,3,3], [2]], N).
N = [3, 3, 3] ;
?- longest([[1],[2], [3,3,3], [2]], N).
N = [3, 3, 3].
?- longest([[1],[2], [3,3,3], [2], [4,4,4,4]], N).
N = [4, 4, 4, 4] .
?- longest([[1],[2], [3,3,3], [2], [4,4,4,4]], N).
N = [4, 4, 4, 4] ;
问候!
于 2009-11-05T19:17:31.953 回答
2
我们longest/2
基于 与 串联使用的元谓词 进行定义:max_of_by/3
length/2
longest(Xss,Ys) :-
max_of_by(Ys,Xss,length).
示例查询:
?- longest([[1],[2]],Xs). % we expect multiple solutions
Xs = [1]
; Xs = [2]. % we _get_ multiple solutions
?- longest([[2,1,3],[7,5],[1,8,2,3,1],[2,7,1,4]],Xs).
Xs = [1,8,2,3,1]. % succeeds deterministically
于 2015-08-06T09:19:25.310 回答
2
这是另一种有效且易于理解的方法。思路是求列表中所有列表的长度,max_list
用来获取最长列表的长度,然后再找一个那么长的列表。这样做的好处是它将返回所有最长长度的列表。
lengths([],[]).
lengths([H|T], [LH|LengthsT]) :-
length(H, LH),
lengths(T, LengthsT).
lengthLongest(ListOfLists, Max) :-
lengths(ListOfLists, Lengths),
max_list(Lengths, Max).
longestList(ListOfLists, Longest) :-
lengthLongest(ListOfLists, Len),
member(Longest, ListOfLists),
length(Longest, Len).
于 2015-12-05T16:16:34.253 回答
0
要获得最长列表的长度:
%sample: longest([[2,1,3],[7,5],[1,8,2,3,1],[2,7,1,4]],L,LEN).
longest([L], L, _) :-
!.
longest([H|T], H, _) :-
length(H, N),
longest(T, X, N),
length(X, M),
N > M,
!.
longest([_|T], X, LEN) :-
length(X, LEN),
longest(T, X, LEN),
!.
于 2011-04-29T13:26:33.503 回答
0
% Correct again.
longest(LL,LX) :-
findmax(Len,(append(_,[L|_],LL),length(L,Len)),MaxLen),
append(_,[LX|_],LL),
length(LX,MaxLen).
findmax(V,P,Max) :-
findall(V,P,L),
max(L,Max).
max([N],N) :- !.
max([N|R],Max) :-
max(R,Max2),
max3(N,Max2,Max).
max3(N,Max2,N) :- N > Max2,!.
max3(N,Max2,Max2).
于 2011-04-29T17:36:37.193 回答