算法概论 习题 8.3
题目描述:
吝啬SAT问题是这样的:给定一组子句(每个子句都是其中文字的析取)和整数k,求一个最多有k个变量为true的满足赋值——如果该赋值存在。证明吝啬SAT是NP-完全问题。
什么是SAT问题?
SAT问题也称为合取范式的可满足问题,一个合取范式形如:A1∧A2∧…∧An,子句Ai(1≤i≤n)形如:a1∨a2∨…∨ak,其中ai为文字,为某一布尔变量或该布尔变量的非。
SAT问题是指:是否存在一组对所有布尔变量的赋值(TRUE或FALSE),使得整个合取范式取指为真。
证明:
我们如果要证明吝啬SAT问题是NP-完全问题,我们首先要证明吝啬SAT问题是NP问题,之后,如果能把SAT问题规约到吝啬SAT问题,那么就能证明吝啬SAT问题是NP-完全问题。
首先,吝啬SAT问题是NP问题 ,因为若已知某个与吝啬SAT问题变量对应的真值集合,可在多项式时间内将该集合带入吝啬SAT问题验证是否为解。故吝啬SAT问题为NP问题。
现在证明SAT问题可以规约到吝啬SAT问题,如果我们把吝啬SAT问题中的k设置为输入的数目,那么SAT问题就可以规约到吝啬SAT问题,所以吝啬SAT问题是NP-完全问题。