Algoritmer, datastrukturer och komplexitet

Relevanta dokument
Algoritmer, datastrukturer och komplexitet

Algoritmer, datastrukturer och komplexitet

Algoritmer, datastrukturer och komplexitet

Algoritmer, datastrukturer och komplexitet

Algoritmer, datastrukturer och komplexitet

Föreläsning 9: NP-fullständighet

Föreläsning 12+13: Approximationsalgoritmer

Föreläsning 7+8: NP-problem. Begreppet effektiv algoritm är alltså synonymt med går i polynomisk tid i den här kursen. Är detta en rimlig uppdelning?

Föreläsning 8+9: NP-problem. Begreppet effektiv algoritm är alltså synonymt med går i polynomisk tid i den här kursen. Är detta en rimlig uppdelning?

Komplexitetsklasser och repetition

Algoritmer, datastrukturer och komplexitet

Föreläsning 8: Intro till Komplexitetsteori

Föreläsning 1. Introduktion. Vad är en algoritm?

Algoritmer, datastrukturer och komplexitet

Övningsmästarprov 2 + några NP-reduktioner. Algoritmer, datastrukturer och komplexitet

Grundläggande logik och modellteori

Föreläsning 9: Turingmaskiner och oavgörbarhet. Turingmaskinen. Den maximalt förenklade modell för beräkning vi kommer använda är turingmaskinen.

Algoritmer, datastrukturer och komplexitet

Algoritmer, datastrukturer och komplexitet

Föreläsningsanteckningar F6

Algoritmer, datastrukturer och komplexitet

Algoritmer, datastrukturer och komplexitet

PCP-satsen på kombinatoriskt manér

Programkonstruktion och Datastrukturer

Föreläsning Datastrukturer (DAT036)

Föreläsning 11. Giriga algoritmer

Föreläsning 5: Grafer Del 1

Föreläsning 5: Dynamisk programmering

Kap.6 Grafer. Egenskaper: Handskakningslemmat och Eulers formel Sats om eulerkrets/väg Isomorfi och representation av grafer Graffärgning

Tommy Färnqvist, IDA, Linköpings universitet

Föreläsning Datastrukturer (DAT037)

Dekomposition och dynamisk programmering

Turingmaskiner och oavgörbarhet. Turingmaskinen. Den maximalt förenklade modell för beräkning vi kommer använda är turingmaskinen.

I en matchning ligger varje hörn i högst en kant. I en stig ligger varje hörn i högst två kanter.

Föreläsning 5: Giriga algoritmer. Kruskals och Prims algoritmer

Föreläsning 8 Datastrukturer (DAT037)

Föreläsning 5: Giriga algoritmer. Kruskals och Prims algoritmer

Föreläsning 7 Datastrukturer (DAT037)

Föreläsning 4: Kombinatorisk sökning

Grundläggande logik och modellteori

DEL I. Matematiska Institutionen KTH

Föreläsning 1. Introduktion och sökning i graf. Vad är en algoritm?

Träd. Sats. Grafer. Definition. En fullständig graf har en båge mellan varje par av noder. Definition

, S(6, 2). = = = =

N = {i}: noder (hörn) Graf: G = (N, B) Definitioner. Väg: Sekvens av angränsande bågar. Cykel: Väg som startar och slutar i samma nod.

Algoritmer och datastrukturer H I HÅKAN S T R Ö M B E R G N I C K L A S B R A N D E F E L T

Föreläsning 8 Datastrukturer (DAT037)

Träd. Sats. Grafer. Definition. En fullständig graf har en båge mellan varje par av noder. Definition

Frågan om P=NP? Är P=NP? Bakgrund. "Snabb lösning"?!

Föreläsning 5 Innehåll

Exempel: Förel Rekursion III Nr 14. Uno Holmer, Chalmers,

Träd. Sats. Grafer. Definition. En fullständig graf har en båge mellan varje par av noder. Definition

Algoritmkomplexitet. Komplexitet Teoretisk bas för frågorna: Är en viss metod bra eller dålig? Är ett visst problem lätt eller svårt?

Träd. Sats. Grafer. Definition. En fullständig graf har en båge mellan varje par av noder. Definition

Introduktion till algoritmer - Lektion 4 Matematikgymnasiet, Läsåret Lektion 4

Tentamen i EDAF05 Algoritmer, datastrukturer och komplexitet

Datastrukturer, algoritmer och programkonstruktion (DVA104, VT 2015) Föreläsning 6

Lösningsförslag för tentamen i Datastrukturer (DAT036) från

Föreläsning 6: Introduktion av listor

n (log n) Division Analysera skolboksalgoritmen för division (trappdivision). Använd bitkostnad.

Tentamensskrivning i Diskret Matematik för CINTE och CMETE, SF1610, onsdagen den 20 augusti 2014, kl

Översikt. Stegvis förfining. Stegvis förfining. Dekomposition. Algoritmer. Metod för att skapa ett program från ett analyserat problem

NP-fullständighetsbevis

Föreläsning 5 Innehåll. Val av algoritm och datastruktur. Analys av algoritmer. Tidsåtgång och problemets storlek

Lösningsförslag för tentamen i Datastrukturer (DAT037) från

Tentamen Datastrukturer för D2 DAT 035

Föreläsning 4 Datastrukturer (DAT037)

Dugga Datastrukturer (DAT036)

Asymptotisk komplexitetsanalys

Lösning till tentamensskrivning i Diskret Matematik, SF1610 och 5B1118, torsdagen den 21 oktober 2010, kl

Föreläsning 4: Giriga algoritmer. Giriga algoritmer

Explorativ övning 9 RELATIONER OCH FUNKTIONER

TDDI16 Datastrukturer och algoritmer. Algoritmanalys

Tentamen Datastrukturer D DAT 035/INN960

Tentamen Datastrukturer D DAT 035/INN960 (med mycket kortfattade lösningsförslag)

Grundläggande logik och modellteori

Föreläsning 9 Innehåll. Söndra och härska. Fibonaccitalen. Söndra och härska. Divide and conquer teknik för att konstruera rekursiva algoritmer.

Tentamen Datastrukturer D DAT 036/INN960

Föreläsning 6 Datastrukturer (DAT037)

Föreläsning 11. Giriga algoritmer

Algoritmer och effektivitet. Föreläsning 5 Innehåll. Analys av algoritmer. Analys av algoritmer Tidskomplexitet. Algoritmer och effektivitet

Datastrukturer och algoritmer

Föreläsning Datastrukturer (DAT036)

Föreläsning 2 Datastrukturer (DAT037)

Föreläsning 2 Datastrukturer (DAT037)

Ekvivalensrelationer

Tillämpad Programmering (ID1218) :00-13:00

Tentamen Datastrukturer (DAT036)

Tommy Färnqvist, IDA, Linköpings universitet

TDDC30. Objektorienterad programmering i Java, datastrukturer och algoritmer. Föreläsning 5 Jonas Lindgren, Institutionen för Datavetenskap, LiU

Speciell användning av heltalsvariabler. Heltalsprogrammering. Antingen-eller-villkor: Exempel. Speciell användning av heltalsvariabler

Föreläsning 13 Innehåll

Algoritmer och datastrukturer TDA143

i=1 c i = B och c i = a i eller c i = b i för 1 i n. Beskriv och analysera en algoritm som löser detta problem med hjälp av dynamisk programmering.

Teoretisk del. Facit Tentamen TDDC (6)

Bakgrund och motivation. Definition av algoritmer Beskrivningssätt Algoritmanalys. Algoritmer. Lars Larsson VT Lars Larsson Algoritmer 1

Datastrukturer. föreläsning 8. Lecture 6 1

Lösning av tentamensskrivning i Diskret Matematik för CINTE och CMETE, SF1610, tisdagen den 27 maj 2014, kl

Transkript:

Algoritmer, datastrukturer och komplexitet Övning 10 Anton Grensjö grensjo@csc.kth.se 9 november 2017 1

Idag En konstruktionsreduktion Fler bevis av NP-fullständighet 2

Teori

Repetition Ett problem tillhör NP om det kan verifieras på polynomisk tid. Ett problem A är NP-svårt om varje problem i NP kan reduceras till A. Ett problem är NP-fullständigt om båda dessa villkor är uppfyllda. 3

Bevis av NP-fullständighet Säg att vi vill visa att problemet A är NP-fullständigt. Då bör vi utföra följande steg: 1. Visa att A NP. a) Föreslå vad en lösning kan vara. b) Visa att om svaret är ja så kan lösningen verifieras. c) Visa att verifikationen tar polynomisk tid (med avseende på indatastorleken). 2. Visa att A är NP-svårt. a) Hitta ett känt NP-fullständigt problem B att reducera. b) Hitta och beskriv en karp-reduktion av B till A. c) Bevisa att reduktionen är polynomisk (med avseende på indatastorleken). d) Bevisa att reduktionen är korrekt. i) Visa att ja-instanser mappas till ja-instanser och nej-instanser till nej-instanser. Vi vet sedan att B p A. 3. Nu har vi visat att A är NP-fullständigt! 4

Pseudopolynomiska algoritmer Betrakta denna algoritm. Vad är tidskomplexiteten? Är den polynomisk? Antag enhetskostnad. 1: function isprime(n) 2: for x 2 to n 1 do 3: if n mod x = 0 then 4: return false 5: return true Tidskomplexitet: O(n). Men vad är tidskomplexiteten uttryckt i storleken på indata? Antalet bitar i indata är b = log n. Tidskomplexiteten kan alltså också skrivas O(2 b ). En algoritm som är exponentiell med avseende på antalet bitar i input men polynomisk med avseende på det största talet i indata kallas för en pseudopolynomisk algoritm. I kontexten av NP-fullständighetsbevis är pseudopolynomiska verifikationer och reduktioner inte okej. 5

Pseudopolynomiska algoritmer I kontexten av NP-fullständighetsbevis är pseudopolynomiska verifikationer och reduktioner inte okej. Varför inte? Definitionerna av NP och NP-svårt kräver polynomisk m.a.p. antalet bitar i indata....men varför? NP definieras med hjälp av turingmaskiner Vad innebär det att en turingmaskin kör på polynomisk tid? Indata är bara en rad bitar på bandet. Den matematiska definitionen av en turingmaskin bryr sig inte om hur dessa bitar tolkas. Det enda rimliga och konsistenta sättet att mäta körtid på är som funktion av antalet bitar i indata. Vi kommer snart se ett exempel på ett NP-fullständigt problem som faktiskt kan lösas med hjälp av en pseudopolynomisk algoritm. 6

Uppgifter

Problem 1: Konstruera kappsäckslösning Kappsäcksproblemet: Beslutsproblem. Indata: Mängd P av föremål med vikt w i och värde v i. Kappsäcksstorlek S. Ett mål K. Fråga: Går det att välja ut föremål av sammanlagt värde minst K så att deras sammanlagda vikt är högst S? Detta är ett känt NP-fullständigt problem. Uppgift: Antag att vi har en algoritm A som löser beslutsproblemet. Konstruera en algoritm som löser det konstruktiva kappsäcksproblemet: Om svaret på A är ja, vilka föremål ska packas ned i kappsäcken? Vi får anropa A O( P ) gånger, men den ska i övrigt gå på polynomisk tid. 7

Problem 1: Konstruera kappsäckslösning Idé: Använd beslutsproblemet för att avgöra om ett element behövs. Om det inte behövs, släng bort det. 1: function Kappsäck(P, S, K) 2: if A(P, S, K) then return Ingen lösning 3: for varje föremål p P do 4: if A(P {p}, S, K) then P P {p} 5: return P Korrekthet P innehåller inga överflödiga element, ty for-slingan löper över alla element i P och tar bort de som är överflödiga. P innehåller en lösning, ty detta är dels uppfyllt innan slingan, och dels efter varje iteration. 8

Kommentar: hur löser man kappsäcksproblemet? Kommentar Kappsäcksproblemet går att lösa på exponentiell men pseudopolynomisk tid med hjälp av dynamisk programmering. Idé: M[i][c] = det maximala värdet som får plats i en kappsäck med kapacitet c om vi bara får använda föremålen 1, 2,..., i. 0 om i = 0 M[i 1][c] om i > 0 och c < w i M[i][c] = max (M[i 1][c], M[i 1][c w i ] + v i ) annars Det optimala värdet är M[ P ][S]. Konstruktionsproblemet kan lösas med backtracking. Tidskomplexitet? O( P S). P begränsas av indatas längd, medan talet S kan växa exponentiellt med avseende på indatas längd. 9

Problem 2: Tillförlitlighet hos internet Bakgrund: Datorer och förbindelser mellan datorer går ofta sönder. Därför vill man att det ska finnas flera alternativa vägar mellan varje par av datorer på internet. T.ex: Om det finns tre olika disjunkta vägar (med avseende på hörn) mellan dator A och B så kan två datorer (vilka som helst) försvinna, utan att förbindelsen mellan A och B försvinner. 10

Problem 2: Tillförlitlighet hos internet Problemet: Se internet som en oriktad graf. Hörn: datorer. Kant från X till Y: en möjlig direktförbindelse mellan X och Y. För varje par av datorer (X, Y) har vi en önskad tillförlitlighet T(X, Y), som säger hur många disjunkta vägar det ska finnas i internet mellan X och Y. Vi har en budget B, som säger hur många direktförbindelser vi ska skapa. Frågan: Kan vi plocka ut en delgraf bestående av B kanter, så att det för alla par av hörn (X, Y) finns minst T(X, Y) disjunkta stigar i delgrafen mellan X och Y? Visa att detta problem är NP-fullständigt! 11

Problem 2: Tillförlitlighet hos internet Beslutsproblem: Givet grafen G, går det att plocka ut en delgraf G bestående av exakt B kanter så att det för alla par av hörn (X, Y) finns minst T(X, Y) disjunkta stigar i G mellan X och Y? Visa att problemet ligger i NP. Lösning? En delgraf G enligt ovan. Tillsammans med, för varje par (X, Y) av noder, en lista över minst T(X, Y) disjunkta stigar. Kan på polynomisk tid verifiera genom att a) Kontrollera att G är en delgraf till grafen. b) Kontrollera att G har exakt B kanter. c) Kontrollera för varje par av hörn att det krävta antalet disjunkta stigar finns specifierade, är korrekta och disjunkta. 12

Problem 2: Tillförlitlighet hos Internet Visa att problemet är NP-svårt. Vilket problem ska vi reducera? Hamiltonsk cykel fungerar fint. 1: function HamCycle(G = (V, E)) 2: B V 3: T(X, Y) 2, X, Y V 4: return InternetBeslut(G, T, B) Reduktionens tidskomplexitet O( V 2 ), polynomiskt i indatastorlek. Korrekthet? 13

Problem 2: Tillförlitlighet hos internet Korrekthet: Antag att vi har en ja-instans s av hamiltonsk cykel, dvs det finns en hamiltoncykel i G. Vi ska då visa att vår konstruerade instans s av InternetBeslut också är en ja-instans. Notera att om vi väljer ut delgrafen G = (V, E ), där E precis innehåller kanterna i hamiltoncykeln, så är det en lösning till InternetBeslut. Varför? Antag att vår konstruerade instans s av InternetBeslut är en ja-instans. Vi vill visa att det existerar en hamiltoncykel i G. Välj två godtyckliga noder X, Y V. Det existerar två disjunkta stigar mellan dem. Unionen av dessa stigar är en hamiltoncykel. Varför? Problemet är således NP-fullständigt. 14

Problem 3: Håstads leksaksaffär Håstads leksaksaffär säljer ett pussel som består av en låda och ett antal kort (se figur). Kort kan placeras i lådan på två sätt, med framsidan upp eller med baksidan upp, eftersom det finns urgröpningar i korten som måste passa in i lister som sitter i lådan. På varje kort finns två kolumner med hål, men vissa av hålen är igenfyllda. Målet med pusslet är att lägga korten i lådan på ett sånt sätt att hela botten täcks; för varje hålposition måste alltså åtminstone ett av korten ha ett igenfyllt hål. Bevisa att följande språk är NP-fullständigt: Toys = { c 1, c 2,..., c n : (c i beskriver kort) (det går att lösa pusslet) } 15

Håstads leksaksaffär 16

Håstads leksaksaffär Visa ligger i NP. Visa NP-svårt. Vilket problem ska vi reducera? Vi kan försöka med CNF-SAT. Givet en CNF-formel φ = (l 1 l 2 l i ) (l j l k ) ( ) med n variabler och m klausuler, vill vi konstruera en en instans γ av Leksaker, som är satisfierbar om och endast om γ är lösbar. 17

Håstads leksaksaffär Vi reducerar problemet enligt följande: 1) Varje variabel x i motsvarar ett kort c i. 2) Det finns två kolumner med m positioner på varje kort, dvs en rad för varje klausul. 3) Det finns ett extra magiskt kort c n+1 med hål endast i den vänstra kolumnen. 4) Om x i finns med i klausul j, så är det vänstra hålet på rad j i c i förtäckt. 5) Om x i finns med i klausul j, så är det högra hålet på rad j i c i förtäckt. 6) Alla andra positioner har hål. Antag att φ är satisfierbar. Då löser vi vårt specialfall γ av Leksaker genom att låta extrakortet ligga rätt väg, låta c i ligga rätt väg om x i = 1, men vända på c i om x i. Alla hål täcks eftersom varje klausul är satisfierad. Omvänt, om γ är löst, välj x i = 1 om c i ligger rätt väg, x i = 0 om c i ligger fel väg. OBS: Vad gör vi om extrakortet är vänt? 18

Håstads leksaksaffär 19

Uppgift 4: Processorschemaläggning Problemet: Vi har n stycken jobb, samt tillräckligt mänga processorer. Varje jobb tar en tidsenhet att göra. Det finns villkor på formen jobb i kan inte exekveras samtidigt som jobb j. Går det att schemalägga jobben på ett sådant sätt att alla jobb är klara efter 3 tidsenheter? Visa att problemet är NP-fullständigt! Visa ligger i NP. Visa NP-svårt. Vilket problem? 3-färgning! 20

Uppgift 4: Processorschemaläggning Vi vill reducera 3-färgning till schemaläggningsproblemet. Låt hörnen i grafen motsvara jobb, samt låt en kant mellan två noter betyda att jobben ej får utföras samtidigt. Vi tolkar de tre färgerna som de tre tidsenheterna. Anropa schemaläggningsproblemet med detta indata och returnera svaret! Korrekthet: Om det finns en trefärgning, så finns det en tillåten schemaläggning. Om det för vår reducerade instans finns en tillåten schemaläggning så motsarar denna en tillåten trefärgning. 21

Nästa gång

Nästa gång Nästa vecka: redovisning av övningsmästarprov 2. Veckan efter det: Hur kan vi hantera NP-fullständiga problem i praktiken? Approximationsalgoritmer Mina slides ligger på Canvas under Moduler/Antons övningsmaterial. 22