• No results found

Typische Examenvragen

N/A
N/A
Protected

Academic year: 2021

Share "Typische Examenvragen"

Copied!
3
0
0

Bezig met laden.... (Bekijk nu de volledige tekst)

Hele tekst

(1)

Typische Examenvragen

Reinoud Berkein May 26, 2018

• Inleiding

– Gegeven ´e´en of andere tabel met probleemgroottes N en uitvoer- ingstijden (zie bvb. doubling experiment). Wat kan je besluiten ivm het gedrag van dit specifieke algoritme?

– Leg het verschil uit tussen grote-O en tilde-notatie om het sti- jgingsgedrag van functies te karakteriseren.

• Selection Sort, Insertion Sort, Merge Sort

– Stel dat ik voor een groot aantal verschillende arrays van verschil- lende lengte N zowel SelectionSort, InsertSort, als MergeSort laat lopen om de arrays te sorteren. Geef een grafiek van de uitvo- eringstijden i.f.v. N (schets de grafiek, verklaar de grafiek, verk- laar het verloop van de verschillende functies, ...) (Belangrijk:

grafieken hebben geen zin als je niet minstens de asssen benoemt, en effectieve getallen op de assen plot. Zeker voor vergelijkingen tussen functies moeten onderlinge verhoudingen juist zijn.)

• Quicksort

– Bewijs dat de tijdscomplexiteit van Quicksort 1.39nlog(n).

– Indien we Quicksort zouden implementeren met 2 pivots (en 3 partities), hoe zou de tijdscomplexiteit zich gedragen? Let op: dit is niet hetzelfde als een 3-way Quicksort waarbij 1 van de partities enkel elementen bevat die gelijk zijn aan de pivot.

– De worst-case tijdscomplexiteit van QuickSort is ∼ n/2, indien men telkens voor elke partitionering, het kleinste dan wel het grootste element als pivot kiest. Men kan echter stellen dat Quick- Sort vrij vergevingsgezind is, en dat, zelfs al we toevallig enkele malen een slechte pivot kiezen gedurende de hele sortering, we toch

1

(2)

een linearitmisch verloop van de rekentijd kunnen verwachten.

Verklaar! (Examenvraag september 2016)

• Sorteren in lineaire tijd

– Een aantal sorteeralgoritmes hebben de eigenschap ”stabiel” te zijn.

∗ Wat wordt hiermee bedoeld?

∗ Welke sorteeralgoritmes die we behandeld hebben in de lessen zijn stabiel?

∗ Waarom is stabiliteit een belangrijke eigenschap van een sor- teeralgoritme?

∗ Kan een niet-stabiel sorteeralgoritme steeds stabiel gemaakt worden?

– Hoe zou je counting sort kunnen wijigen zodat het ook zou werken emt data die geen positieve integers zijn? Bvb ook negatieve in- tegers behandelen? Of ook getallen met decimale fracties (1.5, 2.5, 3.5, ... ?). Welke voorwaarden moeten er gelden voor de te sorteren data?

• Stacks, Queues & Hash Tabellen

– Zie vraag 8 van examen September 2015 (te vinden in folder van examens vorige academiejaren).

• Priority Queues & Balanced Trees

– Geef een bespreking van de insert- operaties in een 2-3 boom.

– Stel dat we ternaire heaps (t.t.z. een heap met 3 kinderen per knoop) zouden gebruiken voor heapsort. Op welke manier zou dit de tijdscomplexiteit be¨ınvloeden?

– Vraag 7 examen september 2016 (Young-tabel). Dit is een mooie illustratie hoe heaps niet noodzakelijk in boomstructuren moeten voorgesteld worden, maar bvb. ook een matrix-vorm mogelijk is.

– Vraag 8, examen juni 2015.

• Greedy Algoritmen

– Gegeven ´e´en of andere string, stel de Huffman coderingsboom op voor deze string.

2

(3)

– Hoe ziet de Huffman codering er uit indien de frequentie van char- acters zich verhoudt tot de Fibonnaci getallen?

– Bewijs dat Huffman-codering optimaal is, t.t.z. de kortst mogeli- jke gecodeerde string oplevert voor een gegeven te coderen string.

• Minimaal Opspannende Bomen en Kortste Pad

– Gegeven ´e´en of andere grafe, geef de volgorde waarin edges/vertices worden toegevoegd in Kruskal/Prim/Dijkstra/..., of geef de toes- tand van de prirotiy queue bij Kruskal/Prim/Dijkstra nadat een specifieke vertex toegevoegd is aan de MST of SPT.

– Leg uit: algoritme van Prim/Kruskal/DIjkstra. Zou je dit algo- ritme beschouwen als een greedy algoritme (argumenteer), dan wel als een dynamisch (dynamische algoritmen komen aan bod in les 10) algoritme (argumenteer), beide (argumenteer), of geen van beide (argumenteer).

• String Matching

– Gegeven een string, stel de bijhorende Knuth-Morris-Pratt toes- tandsmachine op. Zie ook enkele voorbeelden in examenopgaven van vorige jaren.

• Dynamic Programming

– Zou je het algoritme van Dijkstra beschouwen als een dynamisch algoritme, dan wel een greedy algoritme, of beide? Verklaar?

– Een variant op het LCS probleem is de langste subsequentie zoeken in een string die tevens een palindroom is. Zie Vraag 7 in examen van juni 2015.

3

Referenties

GERELATEERDE DOCUMENTEN

Deze voorbeelden en de vormgeving van deze poster zijn ontworpen door de APS–expertgroep rekenen-wiskunde gecijferdheid.. Voor meer informatie kunt u contact opnemen met Kees

Krommen van deze klasse kunnen niet door rationale of trigonometrische functies geparametriseerd worden, w´ el door “ellipti- sche” (dat zijn generalisaties van de

De regelgever zal zich bij de beantwoording in ieder geval onder meer moe- ten afvragen of en in hoeverre de aard van de data daarbij bepalend is – gelden voor data

In figuur 6 zijn twee van deze verbindingslijnstukken als

Als zo jaarlijks 3 procent van alle munten wordt vervangen door buitenlandse euro’s dan heeft, volgens een eenvoudig model, in 2020 nog maar iets meer dan de helft van de munten

De zes grondvlakken van deze piramiden (bovenaan in figuur 4) liggen in één vlak en vormen samen een regelmatige zeshoek ABCDEF.. De diagonalen AD, BE en CF snijden elkaar in het

Voor volledige uitwerkingen verwijs ik je door naar het filmpje dat op de site staat.. Zorg dat je eigen uitwerkingen

Voor volledige uitwerkingen verwijs ik je door naar het filmpje dat op de site staat.. Zorg dat je eigen uitwerkingen