Download presentation
Presentation is loading. Please wait.
1
P, NP and NP-Complete Problems
2
Expected Outcomes Define the class of problems in P, NP, and NPC.
List some problems are in P, NPC respectively.
3
Introduction An algorithm with O(n3) complexity isn’t bad because it can still be run for fairly large inputs in a reasonable amount of time. In this chapter, we are concerned with problems with exponential complexity. Tractable and intractable problems Study the class of problems for which no reasonably fast algorithms have been found, but no one can prove that fast algorithms do not exist. Exponential: takes years or centuries of computer time for moderately large inputs. We’ll present the definitions distinguishing tractable (not-so-hard) and intractable) problems.
4
Tractability An algorithm solves the problem in polynomial time if its worst-case time efficiency belongs to O(p(n)) where p(n) is a polynomial of the problem’s input size n. Problems that can be solved in polynomial time are called tractable. Problems that cannot be solved in polynomial time are called intractable. Why do we care about intractability? Because as the data shows that not all problems can be solved in reasonable amount of time. Before solving a problem, the first question popping into our mind should be : Is this problem tractable?
5
Classifying a Problem’s Complexity
Is there a polynomial-time algorithm that solves the problem? Possible answers: yes no because it can be proved that all algorithms take exponential time because it can be proved that no algorithm exists at all to solve this problem don’t know, but if such algorithms were to be found, then it would provide a means of solving many other problems in polynomial time Classify problems according to their inherent difficulty. 1st don’t know: NP-hard?
6
Types of Problems Optimization problem: construct a solution that maximizes or minimizes some objective function Decision problem: A question that has two possible answers, yes and no. Example: Hamiltonian circles: A Hamiltonian circle in an undirected graph is a simple circle that passes through every vertex exactly once. The decision problem is: Does a given undirected graph have a Hamiltonian circle? Hamiltonian cycle: a cycle passing through all the vertices
7
Some More Problems Many problems will have decision and optimization versions Traveling salesman problem Optimization problem: Given a weighted graph, find Hamiltonian cycle of minimum weight. Decision problem: Given a weighted graph and an integer k, is there a Hamiltonian cycle with total weight at most k? Knapsack : Suppose we have a knapsack of capacity W (a positive integer) and n objects with weights w1, …, wn, and values v1, …, vn (where w1, …, wn, and v1, …, vn are positive integers) Optimization problem: Find the largest total value of any subset of the objects that fits in the knapsack (and find a subset that achieves the maximum value) Decision problem: Given k, is there a subset of the objects that fits in the knapsack and has total value at least k? Bin packing?
8
The class P P : the class of decision problems that can be solved in O(p(n)), where p(n) is a polynomial on n. Why use the existence of a polynomial time bound as the criterion? if not, very inefficient nice closure properties machine independent in a strong sense What is the solvability of a decision problem? Solvable/decidable in polynomial time Solvable/decidable but intractable Unsolvable/undecidable problems: e.g., the halting problem No polynomial algorithm has been found, nor has the impossibility of such an algorithm been proved. Given a computer program and an input to it, determine whether the program will halt on that input or continue working indefinitely on it. Although it is not true that every problem in P has an acceptably efficient algorithm, we can certainly say that if a problem is not in P, it will be extremely expensive and probably impossible to solve in practice. The complexity of the composite algorithm may be bounded by addition, multiplication and composition of the complexities of its component algorithms. Since polynomials are closed under these operations, any algorithm built from several polynomially bounded algorithms in various natural ways will also be polynomially bounded. If an algorithm is polynomially bounded for one machine, it is polynomially bounded for another.
9
The class NP Informally, NP is the class of decision problems for which a given proposed solution for a given input can be checked quickly(in polynomial time) to see if it really is a solution. Formally, NP: the class of decision problems that can be solved by nondeterministic polynomial (NP) algorithms A nondeterministic algorithm: a two-stage procedure that takes as its input an instance I of a decision problem and does the following “guessing” stage: An arbitrary string S is generated that can be thought of as a guess at a solution for the given instance (but may be complete gibberish as well) “verification” stage: A deterministic algorithm takes both I and S as its input and check if S is a solution to instance I, (outputs yes if s is a solution and outputs no or not halt at all otherwise) We say that a nondeterministic algorithm solves a decision problem if and only if for every yes instance of the problem, it returns yes on some execution. (In another word, we require a nondeterministic algorithm to be capable of guessing a solution at least once and to be able to verify its validity.)
10
The class NP A nondeterministic algorithm solves a decision problem if and only if for every yes instance of the problem it returns yes on some execution. A nondeterministic algorithm is said to be polynomially bounded if there is a polynomial p such that for each input of size n for which the answer is yes, there is some execution of the algorithm that produces a yes output in at most p(n) steps.
11
Example: graph coloring
Nondeterministic graph coloring First phase: generate a string s, a list of characters, c1c2…cq ,which the second phase interpret as a proposed coloring solution Second phase: interpret the above characters as colors to be assigned to the vertices ci vi
12
Example: CNF Satisfiability
The problem: Given a boolean expression expressed in conjunctive normal form(CNF), can we assign values true and false to variables to satisfy the CNF ? This problem is in NP. Nondeterministic algorithm: Guess truth assignment Check assignment to see if it satisfies CNF formula Example: (A⋁¬B ⋁ ¬C ) ⋀ (¬A ⋁ B) ⋀ (¬ B ⋁ D ⋁ E ) ⋀ (F ⋁ ¬ D) Truth assignments: A B C D E F … Make the formula true O(n) because the number of operators is n - 1 literals
13
The Relationship between P & NP (1)
(I P I NP): Every decision problem solvable by a polynomial time deterministic algorithm is also solvable by a polynomial time nondeterministic algorithm. To see this, observe that any deterministic algorithm can be used as the checking stage of a nondeterministic algorithm. If I P, and A is any polynomial deterministic algorithm for I, we can obtain a polynomial nondeterministic algorithm for I merely by using A as the checking stage and ignoring the guess. Thus I P implies I NP Coloring problem checking: Given I and S(guess), A can generate Y/N for the question “ Is S a k-colorable solution?” Suppose A is a polynomial alg for the coloring problem. Then given I, A would generate a definite yes/no answer.
14
The Relationship between P & NP (2)
? P = NP (NP P?) Can the problems in NP be solved in polynomial time? A tentative view P NP there is a widespread belief that P != NP, even though no proof of this conjecture appears on the horizon.
15
NP-Completeness (1) NP-completeness is the term used to describe decision problems that are the hardest ones in NP If there were a polynomial bounded algorithm for an NP-complete problem, then there would be a polynomial bounded algorithm for each problem in NP. Examples Hamiltonian cycle Traveling salesman Knapsack Bin packing Graph coloring Satisfiability Some of the sample problems described in the previous section may seem easier than others, but surprisingly, they are all equivalent in the sense that if any one is in P, they all are. They are all NP complete.
16
Informal Definition of NP-Completeness
Informally, an NP-complete problem is a problem in NP that is as difficult as any other problem in this class, because by definition, any other problem in NP can be reduced to it in polynomial time. A decision problem D1 is said to be polynomially reducible to a decision problem D2 if there exists a function t that transforms instances of D1 to instances of D2 such that 1. t maps all yes instances of D1 to yes instances of D2 and all no instances of D1 to all no instances of D2. 2. t is computable by a polynomial-time algorithm. If D2 is polynomially solvable, then D1 can also be solved in polynomial time.
17
An Example of Polynomial Reductions
Problem P: Given a sequence of Boolean values, does at least one of them have the value true? Problem Q: Given a sequence of integers, is the maximum of the integers positive? Transformation T: t(x1, x2, …, xn) = (y1, y2, …, yn), where yi = 1 if xi = true, and yi = 0 if xi = false. FFFT: an instance of P; 0001: an instance of Q based on transformation. FFFF & 0000: no instance.
18
Another Example of Polynomial Reductions
For example a Hamiltonian circuit problem is polynomially reducible to the decision version of the traveling salesman problem. Hamiltonian circuit problem(HCP): Does a given undirected graph have a Hamiltonian cycle? Traveling salesman problem(TSP): Given a weighted graph and an integer k, is there a Hamiltonian cycle with total weight at most k? Transformation t: Map G, a given instance of the HCP to a weighted complete graph G’, an instance of the TSP by assigning 1 as the edge weight to each edge in G and adding an edge of weight 2 between any pair of nonadjacent vertices in G. Let k be n, the total vertex number in G. A yes instance G in HCP: length must be n. its image G’ must be a yes instance because total weight <= n, and it is a HC. A no case G in HCP, e.g., a---b---c (n = 3), its image G’ is also a no case, because the minimum total weight is 4, not < n=4, although we can find a HC.
19
Formal Definition of NP-Completeness
A decision problem D is said to be NP-complete if 1. It belongs to class NP. 2. Every problem in NP is polynomially reducible to D. The class of NP-complete problems is called NPC. Cook’s theorem (1971): discover the first NP-complete problem, CNF-satisfiability problem. Show a decision problem is NP-complete Show that the problem is NP Show that a known NP-complete problem can be transformed to the problem in question in polynomial time. (transitivity of polynomial reduction) Practical value of NP-completeness P NP NP-complete - Implies that if we find a deterministic poly alg for just 1 NP-complete problem, then every problem in NP can be solved in poly time P = NP. - -So far computer scientist has found several hundreds of NPC. Don’t need to bother to find a poly alogrithm for that problem.
Similar presentations
© 2025 SlidePlayer.com. Inc.
All rights reserved.