我在这个答案中找到了这个 Prolog 代码,它使用差异列表实现了一个队列:
%% empty_queue(-Queue)
% make an empty queue
empty_queue(queue(0, Q, Q)).
%% queue_head(?Queue, ?Head, ?Queue0)
% Queue, with Head removed, is Queue0
queue_head(queue(s(X), [H|Q], Q0), H, queue(X, Q, Q0)).
%% queue_last(+Queue0, +Last, -Queue)
% Queue0, with Last at its back, is Queue
queue_last(queue(X, Q, [L|Q0]), L, queue(s(X), Q, Q0)).
做这样的事情它按预期工作:
..., empty_queue(Q), queue_last(Q, 999, Q_), writeln(Q_), ....
我得到
queue(s(0),[999|_3076],_3076)
如果我观察Q
这个片段的价值,也很有趣:
empty_queue(Q), writeln(Q), queue_last(Q, 999, Q_), writeln(Q)
我得到:
queue(0,_3750,_3750)
queue(0,[999|_3758],[999|_3758])
我想应该是这样的,因为差异导致空列表,所以它们有点等价。
问题是,在命令之后
queue_last(Q, 999, Q_)
我不能重用Q
创建一个Q__
,例如:
empty_queue(Q), queue_last(Q, 999, Q_), queue_last(Q, 888, Q__)
因为绑定queue_last(queue(X, Q, [L|Q0]), L, queue(s(X), Q, Q0)).
失败。
L = 888, L = 999 (tries to be both)
我怎么解决这个问题 ?有一些解决方法吗?(总是使用差异列表)