Sunteți pe pagina 1din 28

STRUCTURI DE DATE

Stiva
Coada

STIVA
Structura de tip stiva:
Structura de date logica: implementarea este fcut
utiliznd alte structuri de date;
Structura de date omogena: toate elementele sunt de
acelai tip;
Dou operaii de baz: adugarea i extragerea unui
element;
Disciplina de acces: LIFO-Last In First Out - toate
inserrile (push) i extragerile (pop) sunt fcute la unul
din capetele structurii de implementare, denumit
vrful stivei.
http://www.acs.ase.ro
http://www.itcsolutions.eu

STIVA
push

pop

Mecanismul de stiva
http://www.acs.ase.ro
http://www.itcsolutions.eu

COADA
Structura de tip coada:
Structura de date logica: implementarea este fcut
utiliznd alte structuri de date;
Structura de date omogena: toate elementele sunt de
acelai tip;
Dou operaii de baz: adugarea i extragerea unui
element;
Disciplina de acces: FIFO-Firts In First Out - toate
inserrile (put) se fac la un capat (inceputul cozii) i
extragerile (get) sunt fcute la celalalt capat (sfarsitul
cozii).
http://www.acs.ase.ro
http://www.itcsolutions.eu

COADA

put

get

Mecanismul de coad

http://www.acs.ase.ro
http://www.itcsolutions.eu

STIVE SI COZI - APLICATII


Conversia unei valori zecimale in format binar
1. Preluare valoare zecimala;
2. Cat timp valoarea este strict pozitiva:
2.1 determinare rest impartire la 2;
2.2 prelucrare rest utilizare structura stiva;
2.3 determinare cat impartire la 2.

http://www.acs.ase.ro
http://www.itcsolutions.eu

STIVE SI COZI - APLICATII


QuickSort
Algoritm de tip divide-et-impera;
Reducerea fiecarui set de valori de sortat in 2
sub-seturi;
Aplicarea operatiei de reducere pe fiecare din
cele 2 sub-seturi;
Utilizarea a 2 structuri de tip stiva (Inf, Sup)
pentru stocarea pozitiilor celor 2 sub-seturi.
Stivele sunt initializate: Inf = {1}, Sup = {10}.
http://www.acs.ase.ro
http://www.itcsolutions.eu

STIVE SI COZI - APLICATII


QuickSort exemplu:
Faza de reducere:
extragere varf de stiva Inf (index 1) si varf de
stiva Sup (index 10)
identificare pozitie finala a unei valori din set
(ex. valoare pozitie 1).
13 85 25

64 99 93 49 72 20

Incepand cu pozitia 10, se cauta de la dreapta la


stanga prima valoare mai mica decat 13.
http://www.acs.ase.ro
8
http://www.itcsolutions.eu

STIVE SI COZI - APLICATII


QuickSort exemplu:
Valoare identificata este 9.
13 85 25

64 99 93 49 72 20

Se interschimba 13 cu 9.
9

85 25 13 64 99 93 49 72 20

Incepand cu pozitia lui 9, se cauta de la stanga


spre dreapta prima valoare mai mare decat 13,
pana la pozitia lui 13.
http://www.acs.ase.ro
9
http://www.itcsolutions.eu

STIVE SI COZI - APLICATII


QuickSort exemplu:
Valoare identificata este 85.
9

85 25 13 64 99 93 49 72 20

Se interschimba 85 cu 13.
9

13 25 85 64 99 93 49 72 20

Incepand cu pozitia lui 85, se cauta de la dreapta


la stanga prima valoare mai mica decat 13,
pana la pozitia lui 13.
http://www.acs.ase.ro
10
http://www.itcsolutions.eu

STIVE SI COZI - APLICATII


QuickSort exemplu:
Nu exista nici o valoare, deci pozitia finala a lui 13
este determinata (2).
9

13 25 85 64 99 93 49 72 20

Stivele sunt populate pentru cele 2 subintervale.


Subintervalul stang contine 1 element, deci este
sortat. Nu se retine nimic pe stive.
Subintervalul drept contine cel putin 2 elemente.
Stivele sunt: Inf = {3 } si Sup = {10 }.
http://www.acs.ase.ro
http://www.itcsolutions.eu

11

STIVE SI COZI - APLICATII


QuickSort exemplu:
Faza de reducere:
extragere varf de stiva Inf (index 3) si varf de
stiva Sup (index 10)
identificare pozitie finala a primei valori din set
25.
9

13 25 85 64 99 93 49 72 20

Incepand cu pozitia 10, se cauta de la dreapta la


stanga prima valoare mai mica decat 25.
http://www.acs.ase.ro
12
http://www.itcsolutions.eu

STIVE SI COZI - APLICATII


QuickSort exemplu:
Valoare identificata: 20.
9

13 25 85 64 99 93 49 72 20

Se interschimba 25 cu 20.
9

13 20 85 64 99 93 49 72 25

Incepand cu pozitia lui 20, se cauta de la stanga


la dreapta prima valoare mai mare decat 25.
http://www.acs.ase.ro
http://www.itcsolutions.eu

13

STIVE SI COZI - APLICATII


QuickSort exemplu:
Valoare identificata: 85.
9

13 20 85 64 99 93 49 72 25

Se interschimba 25 cu 85.
9

13 20 25 64 99 93 49 72 85

Incepand cu pozitia lui 85, se cauta de la dreapta


la stanga prima valoare mai mica decat 25.
http://www.acs.ase.ro
http://www.itcsolutions.eu

14

STIVE SI COZI - APLICATII


QuickSort exemplu:
Valoare identificata: -.

13 20 25 64 99 93 49 72 85

Este determinata pozitia 25 in setul final (ordonat),


respectiv pozitia 4.
Stivele sunt populate pentru cele 2 subintervale.
Subintervalul stang contine 1 element, deci este sortat.
Nu se retine nimic pe stive.
Subintervalul drept contine cel putin 2 elemente. Stivele
sunt: Inf = {5} si Sup = {10 }.
http://www.acs.ase.ro
http://www.itcsolutions.eu

15

STIVE SI COZI - APLICATII


QuickSort exemplu:
Faza de reducere:
extragere varf de stiva Inf (index 5) si varf de stiva
Sup (index 10)
identificare pozitie finala a primei valori din set 64.

13 20 25 64 99 93 49 72 85

Incepand cu pozitia 10, se cauta de la dreapta la stanga


prima valoare mai mica decat 64.

http://www.acs.ase.ro
http://www.itcsolutions.eu

16

STIVE SI COZI - APLICATII


QuickSort exemplu:

Faza de reducere se aplica recursiv;


Oprire algoritm: stivele Inf si Sup sunt goale;
Stivele sunt utilizate pentru a retine limitele de
intervale obtinute din modul recursiv de aplicare a
algoritmului.

http://www.acs.ase.ro
http://www.itcsolutions.eu

17

STIVE SI COZI - APLICATII


Evaluarea expresiilor matematice ce utilizeaza
ca structur de date principal stiva:
Rearanjarea expresiei ntr-o anumit form
astfel nct ordinea operaiilor s fie clar i
evaluarea s necesite o singur parcurgere a
expresiei;
Forma polonez: matematicianul de origine
polonez Jan Lukasiewicz;
http://www.acs.ase.ro
http://www.itcsolutions.eu

18

STIVE SI COZI - APLICATII


Evaluarea expresiilor matematice
(continuare):
Forma polonez: scrierea operatorilor
naintea operanzilor;
Forma polonez invers: operatorii sunt
scrii n urma operanzilor.

http://www.acs.ase.ro
http://www.itcsolutions.eu

19

STIVE SI COZI - APLICATII


Forma polonez invers (scriere postfixata):
avantaje fa de scrierea prefixat (forma
poloneza) sau infixat (expresia matematica):
ordinea n care se efectueaz operaiile este
clar;
parantezele nu mai sunt necesare;
evalurile sunt uor de efectuat cu ajutorul
calculatorului.

http://www.acs.ase.ro
http://www.itcsolutions.eu

20

STIVE SI COZI - APLICATII


Un algoritm de transformare din expresie
matematic n scriere postfixat: Edsger
Dijkstra (algoritmul macazului Dijkstra
Shunting Algorithm):
Utilizare stiv n care sunt pstrai operatorii i
din care sunt eliminai i transferai n scrierea
postfixat;
Fiecare operator are atribuit o ierarhie dup
cum este prezentat n tabelul.
http://www.acs.ase.ro
http://www.itcsolutions.eu

21

STIVE SI COZI - APLICATII


Operator
([{
)]}
+*/

Ierarhie
1
2
3
4

Ierarhia operatorilor

http://www.acs.ase.ro
http://www.itcsolutions.eu

22

STIVE SI COZI - APLICATII


Expresia matematic
(scriere infixat)
4+5
4+5*5
4*2+3
4+2+3
4 * (2 + 3)

Expresia n forma
polonez (scriere
prefixat)
+45
+4*55
+*423
++423
*4+23

Expresia n forma
polonez invers
(scriere postfixat)
45+
455*+
42*3+
42+3+
423+*

Forme ale scrierii unei expresii matematice

http://www.acs.ase.ro
http://www.itcsolutions.eu

23

STIVE SI COZI - APLICATII


Algoritmul este:
se iniializeaz stiva i scrierea postfixat;
att timp ct nu s-a ajuns la sfritul expresiei
matematice:
- se citete urmtorul element din expresie;
- dac este valoare se adaug n scrierea postfixat;
- dac este ( se introduce n stiv;
- dac este ) se transfer elemente din stiv n scrierea
postfixat pn la (;

http://www.acs.ase.ro
http://www.itcsolutions.eu

24

STIVE SI COZI - APLICATII


- altfel:
a. att timp ct ierarhia operatorului din vrful
stivei este mai mare ierarhia operatorului
curent, se trece elementul din vrful stivei n
scrierea postfixat;
b. se introduce operatorul curent n stiv.
se trec toi operatorii rmai pe stiv n scrierea
postfixat.

http://www.acs.ase.ro
http://www.itcsolutions.eu

25

STIVE SI COZI - APLICATII


Algoritmul de evaluare:
se iniializeaz stiva;
att timp ct nu s-a ajuns la sfritul scrierii postfixate:
- se citete urmtorul element;
- dac este valoare se depune pe stiv;
- altfel (este operator):
a. se extrage din stiv elementul y;
b. se extrage din stiv elementul x;
c. se efectueaz operaia x operator y;
d. se depune rezultatul pe stiv;
ultima valoare care se afl pe stiv este rezultatul
expresiei.
http://www.acs.ase.ro
http://www.itcsolutions.eu

26

STIVE SI COZI - APLICATII


La nivel de sistem de operare:
Coada procese care asteapta producerea unui
eveniment;
Implementare buffer de mesaje intre procese/sisteme
sub forma de coada;
Zona de memorie utilizata pentru stocarea datelor din
variabile locale, argumente ale functiilor, adrese de
revenire in apelul superior de functie, rezultate stocate
temporar etc;
http://www.acs.ase.ro
http://www.itcsolutions.eu

27

STIVE SI COZI - APLICATII


Suport pentru implementarea/utilizarea altor
structuri de date (Abstract Data Type) prin
stabilirea ordinii fazelor de prelucrare (ex. grafuri).

http://www.acs.ase.ro
http://www.itcsolutions.eu

28

S-ar putea să vă placă și