首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何用Prolog写一个复杂的/3谓词?

如何用Prolog写一个复杂的/3谓词?
EN

Stack Overflow用户
提问于 2012-08-01 03:23:50
回答 1查看 211关注 0票数 1

编写一个谓词complst/3,如果给定的版本具有给定的顺序关系,则该谓词为真。顺序将是: lt、le、gt、ge或eq之一(小于、小于或等于、大于、大于或等于、等于),并且谓词对于所有适用的关系都应该为真。例如,

代码语言:javascript
复制
?- complst([2,3,4], [2,3,5], C).
C = lt ;
C = le .

?- complst([1,2,3,4], [1,1,8], C).
C = gt ;
C = ge .

为了达到目标,我写了一个谓词:

代码语言:javascript
复制
complst([], [], Cmp) :-
    Cmp = eq, !.

complst([A], [B], Cmp) :-
    A > B,
    Cmp = gt.

complst([A], [B], Cmp):-
    A < B,
    Cmp = lt.

complst([A], [B], Cmp):-
    A >= B,
    Cmp = ge.

complst([A], [B], Cmp):-
    A =< B,
    Cmp = le.

complst([], [B], Cmp):-
    Cmp = le, !.

complst([], [B], Cmp):-
    Cmp = lt, !.

complst([A], [], Cmp):-
    Cmp = ge, !.

complst([A], [], Cmp):-
    Cmp = gt, !.

complst([X|XS], [Y|YS], Cmp):-
    X > Y,
    cmp_list([X], [Y], Cmp).

complst([X|XS], [Y|YS], Cmp):-
    X < Y,
    cmp_list([X], [Y], Cmp).

complst([X|XS], [Y|YS], Cmp):-
    X == Y,
    cmp_list(XS, YS, Cmp).

但问题是,除非我按enter键,否则输出永远不会停止。有人能帮我解决这个问题吗??提前感谢!!

EN

回答 1

Stack Overflow用户

发布于 2012-08-01 16:10:17

以这种方式比较两个软件版本列表只有三种可能性。第一个参数小于、等于或大于第二个参数。在第一种情况下,lt,le fit。在第二种情况下,le,eq,ge拟合。在第三个- ge,gt中。

这意味着您可以成对比较两个列表的元素。一旦检测到第一种或第三种情况,您就可以立即生成值。否则,继续到下一对或下一个元素。

沿着两个列表递归的标准框架是

代码语言:javascript
复制
recur( [], [], X):- end_of_two_lists_reached(X).
recur( [], [_|_], X):- second_list_is_longer(X).
recur( [_|_], [], X):- first_list_is_longer(X).
recur( [A|A2], [B|B2], X):- two_elements_are(A,B,C),
  (   continue_recursing(C)
  ->  recur(A2,B2,X) 
  ;   stop_recursing(C,X) 
  ).
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/11747503

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档