Перемешать в прологе - PullRequest
       3

Перемешать в прологе

12 голосов
/ 11 ноября 2011

Я пытаюсь написать процедуру в прологе, где если L1 = [1,2,3] и L2 = [4,5,6], то L3 = [1,4,2,5,3,6]

так shuffle([1,2,3],[4,5,6],[1,4,2,5,3,6])

Пока у меня есть это:

shuffle([X],[Y],[X,Y]).
shuffle([X|Xs],[Y|Ys],_) :- shuffle(Xs,Ys,Z), shuffle(X,Y,Z).

Это моя первая попытка написания прологического кода, поэтому я все еще пытаюсь разобраться в синтаксисе, правилах и прочем.

Я понимаю логику, я просто не уверен, как ее реализовать, поэтому любая помощь будет принята с благодарностью!

Спасибо!

Редактировать: Я понял это. Вот решение, если кому-то интересно:

shuffle([X],[Y],[X,Y]).  
shuffle([X|Xs],[Y|Ys],[Z1,Z2|Zs]) :- shuffle([X],[Y],[Z1,Z2]),shuffle(Xs,Ys,Zs).

Ответы [ 2 ]

20 голосов
/ 11 ноября 2011
shuffle([], B, B).
shuffle([H|A], B, [H|S]) :- shuffle(B, A, S).

В таких задачах обычно трудной частью является не Пролог, а определение простейшего рекурсивного отношения, которое его решает.

1 голос
/ 11 ноября 2011

Вот простое решение:

shuffle([], [], []).
shuffle([X|Xs], [Y|Ys], [X,Y|Zs]) :-
    shuffle(Xs,Ys,Zs).

Обобщая это для обработки списка неравной длины, нужно изменить базовый вариант на:

shuffle(Xs, [], Xs).
shuffle([], Ys, Ys).

, хотя это может привести к дублированию решений,Они могут быть исправлены с помощью сокращения, если вы не возражаете против того, чтобы предикат был «односторонним».

(Хотя я все еще думаю, что вы должны назвать это flatzip или interlace вместо shuffle.)

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...