作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我是 Prolog 新手。我需要编写一个整数加法器,它将 0-9 之间的数字与其他数字 0-9 相加,并产生一个解决方案 0-18。这就是我想做的:
% pseudo code
add(in1, in2, out) :-
in1 < 10,
in2 < 10,
out < 18.
我希望能够这样调用它:
要检查它是否是有效的添加:
?- add(1,2,3).
true.
?- add(1,2,4).
false.
缺少一个变量:
?- add(X,2,3).
X = 1.
?- add(1,4,X).
X = 5.
有多个缺失变量:
?- add(X,Y,Z).
% Some output that would make sense. Some examples could be:
X=1, Y=1, Z=2 ;
X=2, Y=1, Z=3 ......
我意识到这可能是一个非常简单的问题,而且可能非常简单。然而,根据Prolog tutorial我正在使用:
"Unlike unification Arithmetic Comparison Operators operators cannot be used to give values to a variable. The can only be evaluated when every term on each side have been instantiated."
最佳答案
所有现代 Prolog 系统都提供有限域约束,这些约束是可以在所有方向上使用的真实关系(与更底层的算术谓词如 is/2 和 >/2 相比)。在 SWI-Prolog 中:
:- use_module(library(clpfd)).
plus(X, Y, Z) :-
[X,Y] ins 0..9,
X + Y #= Z.
示例结果:
?- plus(1,2,3).
true.
?- plus(1,2,4).
false.
?- plus(X,2,3).
X = 1.
?- plus(1,4,X).
X = 5.
?- plus(X,Y,Z).
X in 0..9,
X+Y#=Z,
Y in 0..9,
Z in 0..18.
由于谓词可以在所有方向上使用,因此将其称为“add/3”不再有意义,因为这意味着一个方向,但谓词真正描述了关系何时成立,因此更通用。
关于Prolog 初学者 : How to unify with arithmetic comparison operators or how to get a set var to range of values,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2981222/
我是一名优秀的程序员,十分优秀!