1 3-COLOURING: Input: Graph G Question: Does there exist a way to 3-colour the vertices of G so that adjacent vertices are different colours? 1.What could.

Slides:



Advertisements
Similar presentations
Max Cut Problem Daniel Natapov.
Advertisements

Theory of Computing Lecture 18 MAS 714 Hartmut Klauck.
1 NP-completeness Lecture 2: Jan P The class of problems that can be solved in polynomial time. e.g. gcd, shortest path, prime, etc. There are many.
NP-Completeness: Reductions
CSC5160 Topics in Algorithms Tutorial 2 Introduction to NP-Complete Problems Feb Jerry Le
Complexity 11-1 Complexity Andrei Bulatov NP-Completeness.
February 23, 2015CS21 Lecture 201 CS21 Decidability and Tractability Lecture 20 February 23, 2015.
Computability and Complexity 15-1 Computability and Complexity Andrei Bulatov NP-Completeness.
Techniques for Proving NP-Completeness
Reduction Techniques Restriction Local Replacement Component Design Examples.
1 CSE 417: Algorithms and Computational Complexity Winter 2001 Lecture 23 Instructor: Paul Beame.
Fall 2006Costas Busch - RPI1 More NP-complete Problems.
1 CSE 417: Algorithms and Computational Complexity Winter 2001 Lecture 24 Instructor: Paul Beame.
CSE 421 Algorithms Richard Anderson Lecture 27 NP Completeness.
Toward NP-Completeness: Introduction Almost all the algorithms we studies so far were bounded by some polynomial in the size of the input, so we call them.
Black-box (oracle) Feed me a weighted graph G and I will tell you the weight of the max-weight matching of G.
Clique Cover Cook’s Theorem 3SAT and Independent Set
February 25, 2015CS21 Lecture 211 CS21 Decidability and Tractability Lecture 21 February 25, 2015.
Nattee Niparnan. Easy & Hard Problem What is “difficulty” of problem? Difficult for computer scientist to derive algorithm for the problem? Difficult.
MCS 312: NP Completeness and Approximation algorithms Instructor Neelima Gupta
1 1. Draw the machine schema for a TM which when started with input 001 halts with abbb on the tape in our standard input format. 2. Suppose you have an.
Lecture 22 More NPC problems
Theory of Computation, Feodor F. Dragan, Kent State University 1 NP-Completeness P: is the set of decision problems (or languages) that are solvable in.
INHERENT LIMITATIONS OF COMPUTER PROGRAMS CSci 4011.
NP-complete Problems SAT 3SAT Independent Set Hamiltonian Cycle
CSCI-256 Data Structures & Algorithm Analysis Lecture Note: Some slides by Kevin Wayne. Copyright © 2005 Pearson-Addison Wesley. All rights reserved. 33.
EMIS 8373: Integer Programming NP-Complete Problems updated 21 April 2009.
Techniques for Proving NP-Completeness Show that a special case of the problem you are interested in is NP- complete. For example: The problem of finding.
NP-Complete Problems. Running Time v.s. Input Size Concern with problems whose complexity may be described by exponential functions. Tractable problems.
1.1 Chapter 3: Proving NP-completeness Results Six Basic NP-Complete Problems Some Techniques for Proving NP-Completeness Some Suggested Exercises.
NP-Completeness (Nondeterministic Polynomial Completeness) Sushanth Sivaram Vallath & Z. Joseph.
CSCI-256 Data Structures & Algorithm Analysis Lecture Note: Some slides by Kevin Wayne. Copyright © 2005 Pearson-Addison Wesley. All rights reserved. 29.
1 Suppose I construct a TM M f which: 1. Preserves its input u. 2. Simulates a machine M b on input ε. 3. If M b hangs on input ε, force an infinite loop.
1 CPSC 320: Intermediate Algorithm Design and Analysis July 30, 2014.
NPC.
CSC 413/513: Intro to Algorithms
NP-Completeness Note. Some illustrations are taken from (KT) Kleinberg and Tardos. Algorithm Design (DPV)Dasgupta, Papadimitriou, and Vazirani. Algorithms.
CSCI 2670 Introduction to Theory of Computing December 2, 2004.
1 CPSC 320: Intermediate Algorithm Design and Analysis July 30, 2014.
CSCI 2670 Introduction to Theory of Computing December 7, 2005.
CSE 421 Algorithms Richard Anderson Lecture 27 NP-Completeness Proofs.
Given this 3-SAT problem: (x1 or x2 or x3) AND (¬x1 or ¬x2 or ¬x2) AND (¬x3 or ¬x1 or x2) 1. Draw the graph that you would use if you want to solve this.
Prof. Busch - LSU1 Busch Complexity Lectures: More NP-complete Problems.
1 1. Which of these sequences correspond to Hamilton cycles in the graph? (a) (b) (c) (d) (e)
COSC 3101A - Design and Analysis of Algorithms 14 NP-Completeness.
COMPLEXITY. Satisfiability(SAT) problem Conjunctive normal form(CNF): Let S be a Boolean expression in CNF. That is, S is the product(and) of several.
The NP class. NP-completeness Lecture2. The NP-class The NP class is a class that contains all the problems that can be decided by a Non-Deterministic.
CSE 332: NP Completeness, Part II Richard Anderson Spring 2016.
TU/e Algorithms (2IL15) – Lecture 10 1 NP-Completeness, II.
Costas Busch - LSU 1 More NP-complete Problems. Costas Busch - LSU 2 Theorem: If: Language is NP-complete Language is in NP is polynomial time reducible.
The NP class. NP-completeness
Richard Anderson Lecture 26 NP-Completeness
More NP-complete Problems
More NP-complete Problems
NP-Completeness (2) NP-Completeness Graphs 7/23/ :02 PM x x x x
Richard Anderson Lecture 26 NP-Completeness
NP-Completeness (36.4-5) P: yes and no in pt NP: yes in pt NPH  NPC
NP-Completeness Yin Tat Lee
CS21 Decidability and Tractability
More NP-complete Problems
Richard Anderson Lecture 25 NP-Completeness
1. for (i=0; i < n; i+=2) if (A[i] > A[i+1]) swap(A[i], A[i+1])
Richard Anderson Lecture 28 NP Completeness
Richard Anderson Lecture 26 NP-Completeness
NP-Completeness Yin Tat Lee
NP-Completeness Yin Tat Lee
Prove this problem is in NP
Richard Anderson Lecture 25 NP Completeness
Instructor: Aaron Roth
Lecture 23 NP-Hard Problems
Presentation transcript:

1 3-COLOURING: Input: Graph G Question: Does there exist a way to 3-colour the vertices of G so that adjacent vertices are different colours? 1.What could you use for a certificate for the 3-colouring problem? 2. Give the pseudo code for a polynomial time algorithm for checking your certificate. Prove this problem is in NP

2 Assignment #5: Available from class web page. Due Friday Dec. 2 at the beginning of class. Final exam tutorial: Sunday Dec. 4 at 12:00pm in ECS 116. There will be tutorials this week.

3 SAT (Satisfiability) Variables: u 1, u 2, u 3,... u k. A literal is a variable u i or the negation of a variable ¬ u i. If u is set to true then ¬ u is false and if u is set to false then ¬ u is true. A clause is a set of literals. A clause is true if at least one of the literals in the clause is true. The input to SAT is a collection of clauses.

4 SAT (Satisfiability) The output is the answer to: Is there an assignment of true/false to the variables so that every clause is satisfied (satisfied means the clause is true)? If the answer is yes, such an assignment of the variables is called a truth assignment. SAT is in NP: Certificate is true/false value for each variable in satisfying assignment.

5 If SAT is solvable in polynomial time, then so is HAMILTON CYCLE. This is on p. 303 in text but there are numerous typos. Use my notes not text. Graph G has n vertices 0, 1, 2, …, n-1. Variables: x i, j : 0 ≤ i, j ≤ n-1 Meaning: Node i is in position j in Hamilton cycle.

6 Variables: x i, j : 0 ≤ i, j ≤ n-1 Meaning- Node i is in position j in Ham. cycle. Conditions to ensure a Hamilton cycle: 1.Exactly one node appears in position j. (a) At least one node appears in position j. For each j, add a clause: (x 0, j OR x 1,j OR x 2, j OR … x n-1, j ) (b) At most one node appears in position j. For each pair of vertices i,k add a clause (not x i, j OR not x k,j )

7 Variables: x i, j : 0 ≤ i, j ≤ n-1 Meaning- Node i is in position j in Ham. cycle. 2. Vertex i occurs exactly once on the cycle. (a) Vertex i occurs at least once. For each i, add a clause: (x i, 0 OR x i,1 OR x i, 2 OR … x i, n-1 ) (b) Vertex i occurs at most once. For each vertex i and pair of positions j,k add a clause (not x i, j OR not x i,k )

8 Variables: x i, j : 0 ≤ i, j ≤ n-1 Meaning- Node i is in position j in Ham. cycle. 3. Consecutive vertices of the cycle are connected by an edge of the graph. For each edge (i, k) which is missing from the graph and for each j add a clause (not x i, j OR not x k,j+1 mod n )

9 Known: SAT is NP-complete. We just proved that if SAT is solvable in polynomial time, then so is HAMILTON CYCLE. Is this a proof that HAMILTON CYCLE is NP-complete?

10 Known: SAT is NP-complete. We showed that if SAT is solvable in polynomial time, then so is HAMILTON CYCLE. Is this a proof that HAMILTON CYCLE is NP- complete? NO. Wrong direction. We would have to show that you can solve SAT in polynomial time using HAMILTON CYCLE instead. Another example: proving you can solve 2- SAT using a SAT solver does not mean 2- SAT is hard.

11 A problem Q in NP is NP-complete if the existence of a polynomial time algorithm for Q implies the existence of a polynomial time algorithm for all problems in NP. How do we prove SAT is NP-complete? Cook’s theorem: SAT is NP-complete.

12 Proving problems are NP-complete. Assuming SAT is NP-complete, we prove that 3-SAT is NP-complete. We use the fact that 3-SAT is NP-complete to prove that VERTEX COVER is NP- complete.

13

14 A set S  V(G) is a vertex cover if every edge of G has at least one vertex in S. Blue: vertex cover Red: independent set VERTEX COVER: Given: G, k Question: Does G have a vertex cover of order k?

15 Theorem: Vertex Cover is NP-complete. Proof: Certificate: vertex numbers of vertices in the vertex cover. To check: for (i=0; i < n; i++) cover[i]= 0; for (i=0; i < k; i++) { scanf(“%d”, &t); if (t = n) {printf(“Bad cover.\n”); exit(0);} else cover[t]= 1; } Read in certificate.

16 for (i=0; i < n; i++) { for (j=i+1; j< n; j++) { if (A[i][j]){ if (cover[i]==0 && cover[j]==0) { printf(“Bad cover.\n”); exit(0); } } printf(“Good cover\n”); Make sure each edge is covered.

17 Pictures from: To solve 3-SAT using vertex cover: 1. For each literal x i, include: 2. For each clause (x i, x j, x k ) use a gadget: Each white vertex connects to the corresponding green one.

18 3-SAT Problem: (x1 or x1 or x2) AND (¬x1 or ¬ x2 or ¬ x2) AND (¬x1 or x2 or x2)

19 At least one vertex from is in the vertex cover. For each gadget, at least 2 vertices are in the vertex cover: Number of variables: n Number of clauses: m When is there a vertex cover of order n + 2m?

20 Put vertices corresponding to true variables in the vertex cover.

21 Satisfying assignment: Each clause has at least one true variable. Put two other vertices into the vertex cover: So each truth assignment corresponds to a vertex cover of order n + 2m.

22 Any vertex cover of order n + 2m corresponds to a satisfying assignment because we can only select at most one of x and ¬x (these are the true variables). The true variables must satisfy each clause since at most 2 vertices can be selected from each clause gadget.

23 A problem Q in NP is NP-complete if the existence of a polynomial time algorithm for Q implies the existence of a polynomial time algorithm for all problems in NP. How do we prove SAT is NP-complete? Cook’s theorem: SAT is NP-complete.