250 likes | 392 Views
Miskolci Egyetem Informatikai Intézet Általános Informatikai Tanszé k Pance Miklós Adatstruktúrák, algoritmusok előadásvázlat 1. Bevezetés Miskolc, 2004 Technikai közreműködő: Imre Mihály, műszaki informatikus hallgató. Bevezetés.
E N D
Miskolci Egyetem Informatikai Intézet Általános Informatikai Tanszék Pance Miklós Adatstruktúrák, algoritmusok előadásvázlat 1. Bevezetés Miskolc, 2004 Technikai közreműködő: Imre Mihály, műszaki informatikus hallgató
Bevezetés Viszonylag állandó tudomány terület, mert nem kötődik szorosan egyetlen konkrét fizikai rendszerhez vagy konfigurációhoz sem. A számítógép belső állapotát leíró rész: az adatkomponens. A műveleteket leíró rész: a kód komponens. Az adatkomponensre vonatkozó utasítások a deklarációk: milyen adatelemek vannak és azok milyen típusúak. Niklaus Wirth: Adatstruktúrák + algoritmusok = programok Algoritmus: Mohamed Al-Khwarizmi (IX.sz.)
Algoritmus fogalma, jellemzői Algoritmus: Egy egyértelmű kiindulási és vég feltétellel megadott feladat megoldási részlépéseinek leírása. Jellemzői: absztrakciós szint (igazodjon a felhasználóhoz),helyesség (sokszor nehezen bizonyítható minden kiinduló állapotra),végesség (az algoritmus maga és a végrehajtás is),hatékonyság (kevesebb lépéssel, kevesebb erőforrással oldja meg a feladatot),egyértelműség (mindig eldönthető a következő lépés.
Egy klasszikus példa LegNagyobb Közös Osztó meghatározása: adott két pozitív egész szám: m, n 1. r = min(m,n) 2. Ha r maradék nélkül osztja m-et és n-et, akkor r a LNKO, vége 3. r = r-1, vissza 2. Pl. m=1215, n=787 esetén a lépések száma: 787 lehet és kell finomítani (RSA titkosítás)
Euclides: LNKO Egy hatékonyabb megoldás, Euclides (ie. 400-300) 1. r = m mod n 2. ha r = 0, akkor n a LNKO, vége 3. m = n, n = r, ugrás 1. Az előző példa megoldásához mindössze 8 lépés szükséges.
Leírási formalizmusok 1. Beszélt nyelv(előző példa) 2. Folyamatábraszimbólumok:művelet döntés adat I/O start/stop nyíl Ezen elemekből 3 alapvető struktúra építhető fel:szekvencia, elágazás, ciklus.
Metanyelv 1. Elágazás:IF (feltétel) igaz ágELSE hamis ágEND Szekvencia:művelet1 művelet2 Értékadás: változó=kifejezés Ciklus: WHILE (feltétel) ciklusmag END 3. Metanyelv, elemei
Metanyelv 2. Függvény deklaráció: FUNCTION függvénynév(formális paraméter lista) utasítások RETURN visszatérő érték END Függvény hívás: függvénynév(aktuális paraméterlista) Operátorok: + - * / < > = stb.
LNKO metanyelven A LNKO algoritmus metanyelven: FUNCTION euclid()INPUT (m, n)r=m%n WHILE (r>0) m=n n=r r=m%nEND OUTPUT (n) END
Algoritmusok hatékonysága 1. 1. Futási idő mérése: megvalósítás ugyanazzal a fejlesztő eszközzel, ugyanazon a gépen futtat.Az eredmény függ: géptípus, konfiguráció, leterheltség, más futó programok, stb.Nem a futási idő a legalkalmasabb. 2. Gépfüggtelenséget kell biztosítani.A műveletek darabszámát mérjük: a műveletek különböző súlyúak, csak a karakterisztikus műveleteket, a feladat nagysága fontos tényező, ezért ez egy függvény (monoton): a laposabb a jobb
Algoritmusok hatékonysága 2. A kiindulási adatoktól is függhet a hatékonyság: • best case (legkedvezőbb eset) • worst case (legkedvezőtlenebb eset) • average case (átlagos eset) Pl. rendezés a szomszédos elemek permutációjával: • csökkenő sorrendbe: 8,7,6,5,4,3,2,1 (best) • növekvő sorrendbe: 8,7,6,5,4,3,2,1 (worst) • növekvő sorrendbe: 2,5,3,1,8,4,7,6 (average)
Algoritmusok hatékonysága 3. FUNCTION keres(x,y,N)t=0; i=1;WHILE (t=0 AND i<=N) IF (x=y[i]) t=1 END i=i+1ENDRETURN t END Az inicializálás költsége: h, a ciklusmagé: r
Algoritmusok hatékonysága 4. best case: h+r worst case: h+r*N average case: h + p*r*(N+1)/2 + (1-p)*r*N(p a valószínűsége, hogy a keresett elem benne van) w a h+r b N 1
Algoritmusok hatékonysága 5. A költségfüggvénynek nem pontos menete, hanem a jellege a fontos. Függvény osztályokat defíniálunk, és ezeket a karakterisztikus függvénnyel adjuk meg. Az függvényosztályba az f-nél laposabban növekvő függvények tartoznak: Az függvényosztályba az f-nél meredekebbennövekvő függvények tartoznak:
Algoritmusok hatékonysága 6. Az függvényosztályba az f-fel kb. azonosan növekvő függvények tartoznak: Két gyakran alkalmazott tétel: T1. f( ), g( ) pozitív értékű függvények, ha , akkor T2. Ha f( ) pozitív értékű függvény, c>0 állandó, akkor
Algoritmusok hatékonysága 6. Pl. A leggyakrabban használt függvénytípusok, sorrendben:
Algoritmusok hatékonysága 7. Példa: alsó háromszög mátrix elemeinek összege: sum=0;FOR i=1 TO nFOR j=1 TO i sum=sum+a[i, j]ENDEND Az összeadások száma: 1+2+3+...+n=n(n+1)/2=(n2+n)/2 Hatékonysága:
Algoritmusok hatékonysága 8. Példa a nagyon eltérő hatékonyságú megoldásokra, határozzuk meg az n elemű A tömb maximális összegű részsorozatát: 1. Három egymásbaágyazott ciklus: 2. Kettő egymásbaágyazott ciklus: 3. Felezés + 2.módszer: 4. Scan-line:
Algoritmusok hatékonysága 9. alapfeladat Osszd meg és uralkodj (divide & conquer) Részf.1. Részf.2. Részf.n. Részm.1. Részm.2. Részm.n. megoldás
Algoritmusok hatékonysága 10. Akkor van értelme, ha Pl. esetén már van értelme, mert De, -nél már nincs.
Algoritmusok hatékonysága 11. A maximális intervallum teljes egészében a baloldali részben, vagy a jobboldaliban, vagy mindkettőben van, ezért:
Algoritmusok hatékonysága 12. Scan line: adatok: 31, -42, 59, 26, -53, 58, 97, -93, -103, 84, 80
Scan line metakód Function maxsum(X,N) sm=0; bm=0; For i=1 To N If (sm+X[i] > 0) sm=sm+X[i]; Else sm=0; End bm= maximum (bm,sm); End Return bm End
Adatstruktúrák, algoritmusok Az adatszerkezetet az algoritmussal együtt vizsgáljuk, egy példa: komplex számok összeadása és szorzása: algebrai alak: z(a,b) polárkoordinátás alak: z(r,φ)