这篇 post 有两个主要的目的:
讨论 Prolog 中的匹配, 解释匹配(match)与相等的不同.
使用 Prolog 搜索的机制解决一些问题.
##Matching
Prolog 中有三种不同的 term, 分别的 constants
, variables
和 complex terms
.
接下来我们解释一下两个 terms 是如何匹配的.
当两个 term 含有相等, 或者两个 term 中的变量在被绑定为指定值之后, 两个 term 相等时, 两个 term 匹配.
也就是说, 以下的 term 都会匹配:
mia = mia.
42 = 42.
mia = X.
X = Y.
friends(john,X) = friends(Y,tom).
接下来我们对匹配进行更精确的定义:
如果 term1 和 term2 都是常量, 那么只有当两者是相同的原子或者相同的数字, term1 term2 匹配.
如果 term1 是变量, term2 是任意类型的 term, 那么 term1 和 term2 匹配, term1 会被绑定为 term2.
如果 term1 term2 是 complex term, 那么在下面情况下, 它们会匹配
它们含有相同的名字和参数数量.
它们对应的参数匹配.
变量的绑定是兼容的, 同一个变量不会同时绑定为两个值.
两个 terms 只有在上述 3 个条件之一成立时, 才会匹配.
匹配有什么作用呢? 我们可以使用匹配来为我们提供更强大的抽象能力:
这两行 Prolog 代码并不是规则, 而是事实, 我们可以使用匹配的能力, 写出这两个规则, 这样我们就可以轻易地判断一条直线是否是垂直的或是水平的.
同样我们也可以利用匹配来寻找与某一点构成垂线的点.
同样我们也可以利用 Prolog 的匹配解决更加复杂更加困难的问题.
现在我们有 6 个单词, 我们需要将它们填入下面的拼图里:
我们可以通过 Prolog 得出答案, 只需要将需要满足的条件写在 predicate 里:
这样我们就可以得到结果:
Prolog 中匹配的能力非常强大, 其实它就是对已经有的条件和数据进行搜索, 尝试所有的答案, 最后给出满足条件的所有结果, 能够极大的降低我们的计算量.
本文转载自 Draveness 技术博客。
原文链接:https://draveness.me/prolog-pi-pei-2
评论