首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >在不创建新统一的情况下查找值

在不创建新统一的情况下查找值
EN

Stack Overflow用户
提问于 2013-05-21 17:51:29
回答 1查看 24关注 0票数 0

我有一组形式为pair/2和谓词propagate/3的定义

代码语言:javascript
运行
复制
pair(1, 2).
pair(2, 3).
pair(3, 4).
pair(4, 5).

propagate([], _, []) :- !.

propagate([pair(N, Num)|Tail], Num, [N|ResultTail]) :-
    propagate(Tail, Num, ResultTail), !.

propagate([pair(Num, N)|Tail], Num, [N|ResultTail]) :-
    propagate(Tail, Num, ResultTail), !.

propagate([_|Tail], Num, Result) :-
    propagate(Tail, Num, Result), !.

如果我有List = [pair(1, 2), pair(2, 3), pair(3, 4), pair(4, 5)]并且我有

代码语言:javascript
运行
复制
propagate(List, 2, Result).

我得到了所需的输出Result = [1, 3];即与2组成一对的所有数字的列表。

但是,如果我有List = [pair(N1, N2), pair(N2, N3), pair(N3, N4), pair(N4, N5)],如果我有

代码语言:javascript
运行
复制
propagate(List, N2, Result)

则输出为

代码语言:javascript
运行
复制
N2 = N3, N3 = N4, N4 = N5,
Result = [N1, N5, N5, N5].

相反,我希望输出为Result = [N1, N3]。我该怎么做呢?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2013-05-21 18:07:35

(==)/2做到了

代码语言:javascript
运行
复制
propagate([], _, []) :- !.

propagate([pair(N, X)|Tail], Num, [N|ResultTail]) :-
    X == Num,
    propagate(Tail, Num, ResultTail), !.

propagate([pair(X, N)|Tail], Num, [N|ResultTail]) :-
    X == Num,
    propagate(Tail, Num, ResultTail), !.

propagate([_|Tail], Num, Result) :-
    propagate(Tail, Num, Result), !.

收益率

代码语言:javascript
运行
复制
?- List = [pair(N1, N2), pair(N2, N3), pair(N3, N4), pair(N4, N5)], propagate(List,N2,Result).
List = [pair(N1, N2), pair(N2, N3), pair(N3, N4), pair(N4, N5)],
Result = [N1, N3].

注意,事实对/2在您的程序中不起任何作用,并且您应该查询一个共享的变量(我使用的是N2而不是P2)。

另外,为什么在规则的末尾有这么多的删减?无用的削减通常是危险的。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/16667038

复制
相关文章

相似问题

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