1)全称:Davis-Putnam-Logemann-Loveland
2)思想:基于树/二叉树的回溯搜索算法,主要基于两种策略。
//伪代码:
bool DPLL(范式S){
while(S中有单子句L){
for(子句P in S){
if(P中有L) 去掉P;
else if(P中有-L) 去掉-L;
}
for循环执行完毕之后,S化简为S1
if(S1 为空) return TRUE;
else if(S1 中含有空子句) return FLASE;
}
按照某种策略选择变元v;
if(DPLL(S∪v)) return TRUE;
//递归回溯部分
else return DPLL(S∪-v);
}
注意:既然是递归算法,自然要注意几个重要的点。其中有一个就是要记得你写的递归是否需要回溯。如果需要回溯,那些中间变量以及标记变量都需要及时回溯。(在传指针的时候尤其需要注意!!!)