有人可以向我解释一下为什么这个序言查询会这样工作吗?定义是:
add(0,Y,Y).
add(succ(X),Y,succ(Z)):- add(X,Y,Z).
鉴于这种:
?- add(succ(succ(succ(0))), succ(succ(0)), R).
这是查询的轨迹:
Call: (6) add(succ(succ(succ(0))), succ(succ(0)), R)
Call: (7) add(succ(succ(0)), succ(succ(0)), _G648)
Call: (8) add(succ(0), succ(succ(0)), _G650)
Call: (9) add(0, succ(succ(0)), _G652)
Exit: (9) add(0, succ(succ(0)), succ(succ(0)))
Exit: (8) add(succ(0), succ(succ(0)), succ(succ(succ(0))))
Exit: (7) add(succ(succ(0)), succ(succ(0)),
succ(succ(succ(succ(0)))))
Exit: (6) add(succ(succ(succ(0))), succ(succ(0)),
succ(succ(succ(succ(succ(0))))))
该教程中最让我困惑的部分是,在第一个参数中,succ 被剥离,并且它会递归。不过,在递归时,R 获得了成功...如何实现?!另外,第一个出口(9)处的零从何而来?我是序言新手,我正在尝试理解作业中的语言。非常感谢任何帮助。
注意:对于任何感兴趣的人,本教程的链接是