首页
学习
活动
专区
圈层
工具
发布

Prolog比
EN

Stack Overflow用户
提问于 2020-12-18 03:23:38
回答 3查看 68关注 0票数 1

在Prolog中找出谁是最高的最简单的方法是什么:

代码语言:javascript
复制
height(lisa,1.65).
height(sam,1.70).
height(luke,1.92).
height(nicole,1.54).

我想写

代码语言:javascript
复制
tallest(X) :- Y is bigger than other Y's
EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2020-12-18 04:02:47

代码语言:javascript
复制
height(lisa,1.65).
height(sam,1.70).
height(luke,1.92).
height(nicole,1.54).

max_height(Person, Height, [[Person, Height]]).
max_height(P , H , [[P, H]|Tail]) :- max_height(_ , H2, Tail), H  > H2.
max_height(P2, H2, [[_, H]|Tail]) :- max_height(P2, H2, Tail), H =< H2.

tallest(X) :- findall([P, H], height(P, H), Bag), max_height(X, _, Bag).

有几种方法可以避免编写max_heightProlog, find minimum in a list

票数 1
EN

Stack Overflow用户

发布于 2020-12-18 04:02:34

SWI-Prolog有一些不同的方法来解决这个问题,例如借助于库(solution_sequences)。

代码语言:javascript
复制
?- order_by([desc(H)],height(P,H)).
H = 1.92,
P = luke ;
...

或使用库(aggregate):

代码语言:javascript
复制
?- aggregate(max(H,P),height(P,H),max(_,P)).
P = luke.

不太复杂的Prologs可能会提供setof/3和last/2:

代码语言:javascript
复制
?- setof(H:P,height(P,H),L),last(L,_:P).
P = luke,
L = [1.54:nicole, 1.65:lisa, 1.7:sam, 1.92:luke].

和更基本的引擎,缺少setof/3,将提供

代码语言:javascript
复制
?- height(P,H),\+((height(_,L),L>H)).
P = luke,
H = 1.92 ;
票数 5
EN

Stack Overflow用户

发布于 2020-12-18 04:39:53

假设tallest(X)成功,当且仅当person X比所有其他人都高时,我认为正确的答案应该是:

代码语言:javascript
复制
tallest(X) :-
    height(X, H),
    forall((height(Y, H1),
            X \= Y),
            H > H1), !.

第一个场景:

代码语言:javascript
复制
height(lisa,1.65).
height(sam,1.70).
height(luke,1.92).
height(nicole,1.54).
代码语言:javascript
复制
?- tallest(X).
X = luke.

第二种情况:

代码语言:javascript
复制
height(lisa,   1.65).
height(sam,    1.70).
height(luke,   1.92).
height(nicole, 1.54).
height(bob,    1.92). % Bob is as tall as Luke!
代码语言:javascript
复制
?- tallest(X).
false.
票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/65347086

复制
相关文章

相似问题

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