1

我正在尝试编写谓词divide(L,Len,Slist),当 Slist 可以与从 List L 分配的长度为 Len 的列表统一时,该谓词将成立。例如

divide([1,2,3,4,5,6,7],3,Slist).

应该给出这样的答案

Slist=[1,2,3];
Slist=[2,3,4];
Slist=[3,4,5];
Slist=[4,5,6];
Slist=[5,6,7];

但是我当时找不到更好的方法,length(X,Len), sublist(L,X).但它确实工作得太慢了。应该怎么看除谓?

4

2 回答 2

2

或者,您可以使用@false 在这个很好的答案中提到的 DCG :

seq([])     --> [].
seq([E|Es]) --> [E], seq(Es).

divide(List, Length, Result) :-
    length(Result, Length),
    phrase((seq(_), seq(Result), seq(_)), List).
于 2012-03-24T23:47:26.713 回答
1

sublist/2 似乎没有按预期工作:

?- [library(dialect/sicstus/lists)].
% library(dialect/sicstus/lists) compiled into sicstus_lists 0,00 sec, 14 clauses
true.

?- L=[1,2,3,4,5,6], length(T, 3),sublist(T,L).
L = [1, 2, 3, 4, 5, 6],
T = [1, 2, 3] ;
L = [1, 2, 3, 4, 5, 6],
T = [1, 2, 4] ;
L = [1, 2, 3, 4, 5, 6],
T = [1, 2, 5] ;
....

您可以改用 append/3 :

?- L=[1,2,3,4,5,6], length(T, 3), append(_, Q, L), append(T, _, Q).
L = [1, 2, 3, 4, 5, 6],
T = [1, 2, 3],
Q = [1, 2, 3, 4, 5, 6] ;
L = [1, 2, 3, 4, 5, 6],
T = [2, 3, 4],
Q = [2, 3, 4, 5, 6] ;
L = [1, 2, 3, 4, 5, 6],
T = [3, 4, 5],
Q = [3, 4, 5, 6] ;
L = [1, 2, 3, 4, 5, 6],
T = Q, Q = [4, 5, 6] ;
false.

我不认为它很快,只是必要的......

于 2012-03-24T20:30:30.847 回答