10.09.2013 Views

Dictaat SOPX3 - Harry Broeders

Dictaat SOPX3 - Harry Broeders

Dictaat SOPX3 - Harry Broeders

SHOW MORE
SHOW LESS

You also want an ePaper? Increase the reach of your titles

YUMPU automatically turns print PDFs into web optimized ePapers that Google loves.

naam insert remove find applicaties implementaties<br />

stack push<br />

O(1)<br />

queue enqueue<br />

O(1)<br />

pull<br />

O(1) LIFO<br />

dequeue<br />

O(1) FIFO<br />

vector O(1) O(n)<br />

schuiven<br />

sorted<br />

vector<br />

linked<br />

list<br />

sorted<br />

list<br />

O(n)<br />

zoeken +<br />

schuiven<br />

top<br />

O(1) LIFO<br />

front<br />

O(1) FIFO<br />

O(n) op<br />

inhoud<br />

O(1) op index<br />

O(n) O(log n) op<br />

inhoud<br />

O(1) op index<br />

dingen omdraaien<br />

is ... gebalanceerd?<br />

evaluatie van expressies<br />

printer queue<br />

wachtrij<br />

vaste lijst<br />

code conversie<br />

lijst waarin je veel<br />

zoekt en weinig muteert<br />

O(1) O(n) O(n) dynamische lijst waarin<br />

je weinig zoekt en verwijdert<br />

O(n) O(n) O(n) dynamische lijst die je<br />

vaak gesorteerd afdrukt<br />

tree O(log n) O(n) O(n) meerdimensionale lijst<br />

file systeem<br />

expressie boom<br />

search<br />

tree<br />

hash<br />

table<br />

priority<br />

queue<br />

O(log n) O(log n) O(log n) dynamische lijst waarin<br />

je veel muteert en zoekt<br />

O(1) O(1) O(1) symbol table (compiler)<br />

dictionary<br />

array, statisch + snel<br />

linked list, dynamisch + meer overhead<br />

in space en time<br />

array, statisch + snel<br />

linked list, dynamisch + meer overhead<br />

in space en time<br />

array, static<br />

random access via operator[]<br />

array, static + binary search algorithm<br />

linked list, dynamic + more space<br />

overhead<br />

sequential access via iterator<br />

more space overhead + minimal n+1<br />

pointers with value 0<br />

sorted binary tree, more space<br />

overhead than list<br />

semi-static, reduced performance if<br />

overfilled<br />

O(log n) O(log n) O(1) event driven simulation binary heap<br />

- array, static + little space overhead<br />

- binary tree, dynamic + space overh.<br />

3 Voorbeelden van het gebruik van een datastructuur.<br />

Als voorbeeld zullen we in dit hoofdstuk enkele toepassingen van de bekende datastructuur stack bespreken.<br />

Een stack is een datastructuur waarin dataelementen kunnen worden opgeslagen. Als de elementen<br />

weer van de stack worden gehaald dan kan dit alleen in de omgekeerde volgorde dan de volgorde waarin<br />

ze op de stack zijn geplaatst. Om deze reden wordt een stack ook wel een LIFO (Last In First Out) buffer<br />

genoemd. Het gedrag van een stack (de interface) kan worden gedefinieerd met behulp van een ABC<br />

(Abstract Base Class). Dit kan bijvoorbeeld als volgt 3 :<br />

#ifndef _THR_Bd_Stack_<br />

#define _THR_Bd_Stack_<br />

template class Stack {<br />

public:<br />

Stack();<br />

virtual ~Stack();<br />

virtual void push(const T& t) =0;<br />

virtual void pop() =0;<br />

virtual const T& top() const =0;<br />

virtual bool empty() const =0;<br />

virtual bool full() const =0;<br />

private:<br />

3 In de ISO/ANSI C++ standaard library is ook een type stack gedefinieerd, zie hoofdstuk 6.<br />

Software Ontwikkeling & Programmeren 3 <strong>Harry</strong> <strong>Broeders</strong><br />

11

Hooray! Your file is uploaded and ready to be published.

Saved successfully!

Ooh no, something went wrong!