前面提到过,PROLOG语言求解问题的方式与基于规则的逆向演绎系统非常类似。那么在与事实或者规则匹配时,PROLOG系统的搜索策略是什么呢?其基本的求解策略是:从上到下,从左到右,深度优先。也就是说,在寻找匹配的子句的时候,按照书写的顺序,从上到下搜索。在判断规则的若干个条件是否成立的时候,按照规则中子句的顺序,从左到右进行判断。在判断一个条件是否成立的时候,该条件是否成立可能与其他的规则或事实有关,这时按照深度优先的策略,一直进行下去,直到判断出该条件成立或者不成立为止。 则PROLOG按自上而下的次序对子句进行搜索,寻找句首与问题匹配的第一个子句。在该例中,首先与第一个子句匹配,其结果使得X=john,Y=bob,与句首匹配后,将偿试该子句的句体是否成功,因这时X与Y已有约束值,则句体变为child(John,Bob),由于它与任何其它的子句均不能匹配,因而失败,PROLOG自动进行回溯,重新寻找可匹配的子句,这样就搜索到了第二个子句,并与其句首匹配,使得X=john,Z=bob,而其句体成为child(john,Y)和descendant(Y,bob)。第一项刚好与child(john,mary)匹配,从而Y=mary,第二项变成descendant(mary,bob)。不难得出它也不能匹配,故再次回溯,重新匹配第一项,使得第一项成为child(john,bill),第二项成为descendant(bill,bob),它与第一个子句的句首匹配,使其句体成为child(bill,bob),而它刚好有与其匹配的事实,故询问得到解答,回答yes。当询问中有变量存在时,其匹配过程与此相仿,只是当匹配成功之后,将变量的值显示出来。 cut符号"!"是用户能够控制PROLOG运行的唯一手段,使用得当的话,可以起到提高效率的作用。"!"像一个"单通道"一样,PROLOG系统一旦通过了它,就不能回溯到其前面去了,起到了阻止回溯的作用。 在PROLOG中使用符号"!"(读作cut)可以控制回溯,这对提高程序的运行效率带来很大的好处。当在询问中遇到"!"时,它象一座墙一样,阻止了PROLOG的回溯,使得回溯只能在它后面进行。例如,我们要查找tom的叔叔,可以询问: |