Warning: foreach() argument must be of type array|object, bool given in /var/www/html/web/app/themes/studypress-core-theme/template-parts/header/mobile-offcanvas.php on line 20

Show that if P=NP, a polynomial time algorithm exists that produces a satisfying assignment when given a satisfiable Boolean formula. (Note: The algorithm you are asked to provide computes a function; but NPcontains languages, not functions. The P=NPassumption implies that SATis in P, so testing satisfiability is solvable in polynomial time. But the assumption doesn’t say how this test is done, and the test may not reveal satisfying assignments. You must show that you can find them anyway. Hint: Use the satisfiability tester repeatedly to find the assignment bit-by-bit.)

Short Answer

Expert verified

Choose x1=1if ϕ0is satisfiable; otherwise, choose x1=1if ϕ1 is satisfiable. In a satisfied assignment, this gives the value of x1. Make the replacement permanent, and in the same way, find a value for x2in a satisfying assignment. Continue unitl all the variables are substituted.

Step by step solution

01

Step-1: SAT

The (Boolean Satisfiability Challenge) is the problem of finding whether or not a given boolean formula has an interpretation that satisfies it. It examines whether the variables in a given boolean formula can be consistently replaced with the values TRUEor FALSE, resulting in the formula evaluating to TRUE. The formula is said to be satisfiable if this is the case. If no such assignment occurs, the formula's function isFALSE for all conceivable variable assignments, thus the formula is unsatisfactory.

02

Step-2: Explanation

There exists a polynomial time technique for deciding SATifP=NP. Substitute x1=0andx1=1 in to create a satisfactory assignment for a satisfiable formula ϕ , and then test the satisfiability of the two resulting formulas ϕ0 and ϕ1. Because ϕ is satisfiable, at least one of them must be satisfiable. Choose x1=1if role="math" localid="1663243564370" ϕ0 is satisfiable; otherwise, choose x1=1if ϕ1 is satisfiable. In a satisfied assignment, this gives the value of x1. Make the replacement permanent, and in the same way, find a value for x2 in a satisfying assignment. Continue until substituted all of the variables.

One App. One Place for Learning.

All the tools & learning materials you need for study success - in one app.

Get started for free

Study anywhere. Anytime. Across all devices.

Sign-up for free