序言中的随机播放 [英] Shuffle in prolog

查看:14
本文介绍了序言中的随机播放的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我正在尝试在 prolog 中编写一个过程,如果 L1 = [1,2,3] 和 L2 = [4,5,6] 然后 L3 = [1,4,2,5,3,6]

I'm trying to write a procedure in prolog where if L1 = [1,2,3] and L2 = [4,5,6] then 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).

这是我第一次尝试编写 prolog 代码,所以我仍在努力思考语法、规则和所有内容.

This is my first attempt at writing prolog code so I'm still trying to wrap my head around the syntax, rules and everything.

我理解逻辑,我只是​​不确定如何实现它,所以任何帮助将不胜感激!

I understand the logic, I'm just not sure how to implement it so any help would be greatly appreciated!

谢谢!

我已经弄明白了.如果有人感兴趣,这是解决方案:

I've figured it out. Here's the solution if anyone's interested:

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

推荐答案

shuffle([], B, B).
shuffle([H|A], B, [H|S]) :- shuffle(B, A, S).

在这类问题中,困难的部分通常不是 Prolog,而是找出解决它的最简单的递归关系.

In this kind of problems, usually the difficult part is not Prolog but identifying the simplest recursive relation that solves it.

这篇关于序言中的随机播放的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆