Partíció probléma rekurzíómemorizálással



Hasonló dokumentumok
Fibonacci számok. Dinamikus programozással

Megoldás meghatározása Ez a szakasz kitölti a c és S táblázatokat, a kiíratás S alapján egy rekurzív algoritmussal megtehető.

Dinamikus programozás II.

Programozási módszertan. Dinamikus programozás: szerelőszalag ütemezése Mátrixok véges sorozatainak szorzása

Dinamikus programozás vagy Oszd meg, és uralkodj!

Programozási módszertan. Dinamikus programozás: A leghosszabb közös részsorozat

Mohó algoritmusok. Példa:

Programozási módszertan. Mohó algoritmusok

Specifikáció. B logikai formula, a bemeneti feltétel, K logikai formula, a kimeneti feltétel, A az algoritmus, amelyre az állítás vonatkozik.

Programozási módszertan. Dinamikus programozás: Nyomtatási feladat A leghosszabb közös részsorozat

Optimalizációs stratégiák 1.

Korlátozás és szétválasztás elve. ADAGOLO adattípus

Hátizsák feladat. Példa: A tárgyak (súly, fontosság) párokban (4,6) (3,5) (2,3) (2,3) a hátizsák kapacitása 8.

Általános algoritmustervezési módszerek

Dinamikus programozás - Szerelőszalag ütemezése

2. Rekurzió. = 2P2(n,n) 2 < 2P2(n,n) 1

INFORMATIKA javítókulcs 2016

Hátizsák feladat. Példa: A tárgyak (súly, fontosság) párokban (4,6) (3,5) (2,3) (2,3) a hátizsák kapacitása 8.

Specifikáció. B logikai formula, a bemeneti feltétel, K logikai formula, a kimeneti feltétel, A az algoritmus, amelyre az állítás vonatkozik.

Algoritmizálás, adatmodellezés tanítása 8. előadás

Gyakorlatok. P (n) = P (n 1) + 2P (n 2) + P (n 3) ha n 4, (utolsó lépésként l, hl, u, hu-t léphetünk).

Algoritmusok és adatszerkezetek gyakorlat 03 Oszd meg és uralkodj. Nagy

Amortizációs költségelemzés

angolul: greedy algorithms, románul: algoritmi greedy

Programozási módszertan. Függvények rekurzív megadása "Oszd meg és uralkodj" elv, helyettesítő módszer, rekurziós fa módszer, mester módszer

Dinamikus programozás párhuzamosítási lehetőségekkel

Edényrendezés. Futási idő: Tegyük fel, hogy m = n, ekkor: legjobb eset Θ(n), legrosszabb eset Θ(n 2 ), átlagos eset Θ(n).

Lineáris algebra (10A103)

A félév során előkerülő témakörök

Összetett programozási tételek Rendezések Keresések PT egymásra építése. 10. előadás. Programozás-elmélet. Programozás-elmélet 10.

Az B sorozatban a pontok helyes preorder sorrendben vannak. A preorder bejárásban p k -t közvetlenül q m követi.

Dinamukus programozás

Algoritmusok és adatszerkezetek I. 10. előadás

Algoritmuselmélet. Legrövidebb utak, Bellmann-Ford, Dijkstra. Katona Gyula Y.

Algoritmizálás. Horváth Gyula Szegedi Tudományegyetem Természettudományi és Informatikai Kar

Permutáció n = 3 esetében: Eredmény: permutációk száma: P n = n! romámul: permutări, angolul: permutation

BBTE Matek-Infó verseny mintatételsor Informatika írásbeli vizsga

Előfeltétel: legalább elégséges jegy Diszkrét matematika II. (GEMAK122B) tárgyból

end function Az A vektorban elõforduló legnagyobb és legkisebb értékek indexeinek különbségét.. (1.5 pont) Ha üres a vektor, akkor 0-t..

Példa Hajtsuk végre az 1 pontból a Dijkstra algoritmust az alábbi gráfra. (A mátrixban a c i j érték az (i, j) él hossza, ha nincs él.

Felvételi tematika INFORMATIKA

Példa Hajtsuk végre az 1 pontból a Dijkstra algoritmust az alábbi gráfra. (A mátrixban a c i j érték az (i, j) él hossza, ha nincs él.

i=1 i+3n = n(2n+1). j=1 2 j < 4 2 i+2 16 k, azaz az algoritmus valóban konstans versenyképes.

Műveletek mátrixokkal. Kalkulus. 2018/2019 ősz

2. Milyen értéket határoz meg az alábbi algoritmus, ha A egy vektor?. (2 pont)

Branch-and-Bound. 1. Az egészértéketű programozás. a korlátozás és szétválasztás módszere Bevezető Definíció. 11.

Dr. Schuster György február / 32

Felvételi vizsga mintatételsor Informatika írásbeli vizsga

BABEŞ BOLYAI TUDOMÁNYEGYETEM MATEMATIKA ÉS INFORMATIKA KAR BBTE Matek-Infó verseny 1. tételsor INFORMATIKA írásbeli. A versenyzők figyelmébe:

2018, Diszkrét matematika

Bonyolultságelmélet. Thursday 1 st December, 2016, 22:21

Mesterséges Intelligencia. Csató Lehel. Csató Lehel. Matematika-Informatika Tanszék Babeş Bolyai Tudományegyetem, Kolozsvár 2007/2008

Algoritmusokfelülnézetből. 1. ELŐADÁS Sapientia-EMTE

Algoritmizálás, adatmodellezés tanítása 7. előadás

2. Visszalépéses keresés

A 2016/2017 tanévi Országos Középiskolai Tanulmányi Verseny első forduló javítási-értékelési útmutató. INFORMATIKA II. (programozás) kategória

2015, Diszkrét matematika

Kupac adatszerkezet. A[i] bal fia A[2i] A[i] jobb fia A[2i + 1]

Gráfelméleti feladatok. c f

Programozás alapjai II. (7. ea) C++ Speciális adatszerkezetek. Tömbök. Kiegészítő anyag: speciális adatszerkezetek

Egész számok. pozitív egész számok: 1; 2; 3; 4;... negatív egész számok: 1; 2; 3; 4;...

Speciális adatszerkezetek. Programozás alapjai II. (8. ea) C++ Tömbök. Tömbök/2. N dimenziós tömb. Nagyméretű ritka tömbök

Gráfok, definíciók. Gráfok ábrázolása. Az adott probléma megoldásához ténylegesen mely műveletek szükségesek. Ábrázolások. Példa:

Algoritmuselmélet 12. előadás

Algoritmusok bonyolultsága

Programozás alapjai II. (7. ea) C++

Adatszerkezetek II. 10. előadás

10. gyakorlat Struktúrák, uniók, típusdefiníciók

A MAXIMUM-KUPACOL eljárás helyreállítja az A[i] elemre a kupactulajdonságot. Az elemet süllyeszti cserékkel mindaddig, amíg a tulajdonság sérül.

LINEÁRIS PROGRAMOZÁSI FELADATOK MEGOLDÁSA SZIMPLEX MÓDSZERREL

2. Visszalépéses stratégia

Sapientia - Erdélyi Magyar TudományEgyetem (EMTE) Csíkszereda IRT- 4. kurzus. 3. Előadás: A mohó algoritmus

Alkalmazott modul: Programozás 4. előadás. Procedurális programozás: iteratív és rekurzív alprogramok. Alprogramok. Alprogramok.

Érdekes informatika feladatok

Gauss-Seidel iteráció

3. Előadás. Megyesi László: Lineáris algebra, oldal. 3. előadás Lineáris egyenletrendszerek

I. VEKTOROK, MÁTRIXOK

Számjegyes vagy radix rendezés

Információk. Ismétlés II. Ismétlés. Ismétlés III. A PROGRAMOZÁS ALAPJAI 2. Készítette: Vénné Meskó Katalin. Algoritmus. Algoritmus ábrázolása

5. Előadás. (5. előadás) Mátrixegyenlet, Mátrix inverze március 6. 1 / 39

Számláló rendezés. Példa

1. ábra. Számláló rendezés

Mesterséges intelligencia 1 előadások

Algoritmuselmélet 1. előadás

Matematikai problémák vizsgálata a Maple programcsomag segítségével

Numerikus integrálás

Számítógépes döntéstámogatás. Genetikus algoritmusok

1. ábra. Egy rekurzív preorder bejárás. Egy másik rekurzív preorder bejárás

Kupac adatszerkezet. 1. ábra.

A 2013/2014 tanévi Országos Középiskolai Tanulmányi Verseny első forduló javítási-értékelési útmutató. INFORMATIKA II. (programozás) kategória

/* Az iter függvény meghívása és a visszatérő érték átadása a gyok változóba */ gyok = iter( n, a, e ) ;

Módosítható Prioritási sor Binomiális kupaccal. Wednesday, March 21, 12

Kombinatorikai algoritmusok. (Horváth Gyula és Szlávi Péter előadásai felhasználásával)

A 2011/2012 tanévi Országos Középiskolai Tanulmányi Verseny első forduló feladatainak megoldása. INFORMATIKÁBÓL II. (programozás) kategóriában

Kombinatorikai algoritmusok

Rekurzió. (Horváth Gyula és Szlávi Péter előadásai felhasználásával)

Sorozatok és Sorozatok és / 18

Mátrixjátékok tiszta nyeregponttal

Algoritmuselmélet 2. előadás

Rendezések. A rendezési probléma: Bemenet: Kimenet: n számot tartalmazó (a 1,a 2,,a n ) sorozat

Átírás:

Partíció probléma rekurzíómemorizálással A partíciószám rekurzív algoritmusa Ω(2 n ) műveletet végez, pedig a megoldandó részfeladatatok száma sokkal kisebb O(n 2 ). A probléma, hogy bizonyos már megoldott részfeladatokat az algoritmus nagyon sokszor újra kiszámol. Megoldás: jegyezzük fel a kiszámolt értéket, és ha már megvan nincs szükség rekurzív hívásra. PARTÍCIÓRM(n) Return P2(n,n) P2RM(n,k) if T[n,k]>0 then return T[n,k] if (k=1) Or (n=1) then {T[n,k]:=1 return 1} else if k>=n then {T[n,k]:=P2RM(n,n-1)+1 return T[n,k]} else {T[n,k]:=P2RM(n,k-1)+P2RM(n-k,k) return T[n,k]} A futási idő és tárigény O(n 2 ). Partíció négyzetes táblázatkitöltéssel A rekurziót teljesen kiküszöbölhetjük táblázat-kitöltéssel. A T2[n,k] táblázatelem tartalmazza a P2(n,k) részprobléma megoldását. A táblázat első sora azonnal kitölthető, mert P2(n, 1) = 1. Olyan kitöltési sorrendet keresünk, hogy minden (n, k), k > 1 részprobléma kiszámítása esetén azok a részproblémák, amelyek szükségesek P2(n, k) kiszámításához, már korábban kiszámítottak legyenek. Általánosan, rekurzív összefüggéssel definiált problémamegoldás esetén egy r (rész)probléma összetevői azok a részproblémák, amelyek megoldásától r megoldása függ. Tehát a táblázatkitöltés alkalmazásához meg kell állapítani a részproblémáknak egy olyan sorrendjét, hogy minden r részprobléma minden összetevője előrébb álljon a sorrendben, mint r. A rekurzív összefüggések megadják az összetevőket: P2(1,k) = 1, P2(n,1) = 1, P2(n,n) = 1+P2(n,n-1), P2(n,k) = P2(n,n) ha n < k, P2(n,k) = P2(n,k-1)+P2(n-k,k) ha k < n. Összetevők: P2(1,k)-nak és P2(n,1)-nek nincs összetevője, P2(n,n) összetevője P2(n,n-1), P2(n,k) összetevője P2(n,n), ha (n < k), P2(n,k) összetevői: P2(n,k-1) és P2(n-k,k), ha (k < n). Tehát a táblázat kitöltése (k-szerint) soronként balról jobbra haladó lehet. Az algoritmus futási ideje és tárigénye is O(n 2 ). 1

ParticioDin for i:=1 to n T[i,1]:=1 for j:=2 to n {T[j,j]=T[j,j-1]+1 for r:=j+1 to n {p:=min(r-j,j) T[r,j]:=T[r,j-1]+T[r-j,p]}} return T[n,n] 1. táblázat. A partíció algoritmus táblázata - - - - 7 - - - 5 6 - - 3 4 5-2 2 3 3 1 1 1 1 1 2. táblázat. A partíció algoritmus teljes táblázata 1 2 3 5 7 1 2 3 5 6 1 2 3 4 5 1 2 2 3 3 1 1 1 1 1 Partíció lineáris táblázatkitöltéssel Látható, hogy elegendő lenne a táblázatnak csak két sorát tárolni, mert minden (n,k) részprobléma összetevői vagy a k-adik, vagy a k-1-edik sorban vannak. Sőt, elég egy sort tárolni balról jobbra (növekvő n-szerint) haladó kitöltésnél, mert amelyik részproblémát felülírjuk (n-k,k), annak később éppen az új értéke kell összetevőként. ParticioDin2 for i:=1 to n do T[i]:=1 for j:=2 to n {T[j]=T[j]+1 for r:=j+1 to n T[r]:=T[r]+T[r-j]} return T[n] Mátrixszorzás probléma Ha egy i j méretű mátrixot és egy j k méretű mátrixot szorzunk össze a skalár műveletek száma i jk. A mátrixok szorzása asszociatív, az elvégzendő skalár műveletek száma függ a zárójelezéstől. Példa: Legyenek A 1,A 2,A 3 méretei 2 3, 3 4, 4 5. Ekkor: - (A 1 A 2 )A 3 24+40=64 műveletet hajt végre - A 1 (A 2 A 3 ) pedig 60+30=90 műveletet. A mátrixszorzás probléma feladata egy adott szorzás optimális zárójelezésének megtalálása. Az input: A 1,A 2,...A n, ahol A i mérete p i 1 p i. 2

Részprobléma: A i...a j optimális zárójelezése minden i, j párra, a megoldás értéke legyen m[i, j]. Nyilvánvaló, hogy m[i,i] = 0. Rekurzív összefüggés: Ha a szorzásnál az első zárójelpár hátsó zárójele az A k után kerül, akkor a költség: m[i,k]+ m[k + 1, j] + p i 1 p k p j. Ezen lehetőségek közül választjuk a legjobbat, így ha i < j, akkor m[i, j] = min i k< j {m[i,k] + m[k + 1, j] + p i 1 p k p j }. Táblázatkitöltés: m[i,j]-hez használjuk az m[i,k] és m[k+1,j] értékeket, ezeknek kell meglenni az m[i,j] érték számításánál. Így a helyes kitöltési sorrend átlónként megy (elsőként a j=i, értékek, aztán j=i+1, majd j=i+2 és így tovább). A megoldás meghatározását feljegyzéses módszerrel oldjuk meg, S[i,j]-ben feljegyezzük, hogy mi volt az optimális döntés m[i,j] számításakor. MATRIXSZORZAS for i:=1 to n m[i,i]=0 for l:=2 to n {for i:=1 to n-l+1 {j:=i+l-1 m[i,j]:=inf for k:=i to j-1 {q:= m[i,k]+m[k+1,j]+p(i-1)p(k)p(j) If q<m[i,j] then {m[i,j]:=q S[i,j]:=k}}}} A fenti a szakasz kitölti az m és S táblázatokat, a kiíratás S alapján egy rekurzív algoritmussal megtehető. KIIR(i,j) If j>i Then Print "(" KIIR(i,S[i,j]) KIIR(S[i,j]+1,j) Print ")" Else Print "A(i)" Példa: A 1 (6 7), A 2 (7 3), A 3 (3 1), A 4 (1 2), A 5 (2 4) 3. táblázat. Az m[i,j] értékek táblázata 0 0 0 0 0 0 0 0 0 8 0 0 0 6 20 0 0 21 35 57 0 126 63 75 95 m[1,3] = min{[m[1,1] + m[2,3] + 6 7 1,m[1,2] + m[3,3] + 6 3 1} = 63 m[2,4] = min{[m[2,2] + m[3,4] + 7 3 2,m[2,3] + m[4,4] + 7 1 2} = 35 m[3,5] = min{[m[3,3] + m[4,5] + 3 1 4,m[3,4] + m[5,5] + 3 2 4} = 20 m[1,4] = min{[m[1,1] + m[2,4] + 6 7 2,m[1,2] + m[3,4] + 6 3 2,m[1,3] + m[4,4] + 6 1 2} = 75 3

4. táblázat. Az S[i,j] értékek táblázata 0 0 0 0 0 0 0 0 0 4 0 0 0 3 3 0 0 2 3 3 0 1 1 3 3 Megoldás: ((A 1 )(A 2 A 3 ))(A 4 A 5 ) A dinamikus programozás stratégiája. A dinamikus programozás, mint probléma-megoldási stratégia az alábbi öt lépés végrehajtását jelenti. 1. Az [optimális] megoldás szerkezetének elemzése. 2. Részproblémákra és összetevőkre bontás úgy, hogy az összetevőktől való függés körmentes legyen. Minden részprobléma [optimális] megoldása kifejezhető legyen (rekurzívan) az összetevők [optimális] megoldásaival. 3. Részproblémák [optimális] megoldásának kifejezése (rekurzívan) az összetevők [optimális] megoldásaiból. Az 1-3 pontok lényegében egy rekurzív algoritmus megtervezését jelentik. 4. Részproblémák [optimális] megoldásának kiszámítása alulról-felfelé haladva. (A részproblémák kiszámítási sorrendjének meghatározása. Olyan sorba kell rakni a részproblémákat, hogy minden p részprobléma minden összetevője előrébb szerepeljen a felsorolásban, mint p. A részproblémák kiszámítása a sorrendnek megfelelően haladva, azaz táblázat-kitöltéssel. 5. Egy [optimális] megoldás előállítása a 4. lépésben kiszámított (és tárolt) információkból. Visszafejtéses vagy feljegyzéses módszer. Mikor érdemes dinamikus programozást használni? Optimális résztruktúrájú feladat: a probléma egy részfeladatának optimális megoldása önmagán belül a további részfeladatok optimális megoldásait is tartalmazza. Átfedő részfeladatok: egy rekurzív algoritmus, ismételten visszatér ugyanazokra a részfeladatokra. (Oszd meg és uralkodj típusú rekurzív algoritmusoknál általában nincs ilyen probléma.) Leghosszabb közös részsorozat Egy sorozat, akkor részsorozata egy másiknak, ha abból elemeinek elhagyásával megkapható. A feladat két sorozat X = (x 1,...,x m ) és Y = (y 1,...,y n ) leghosszabb közös részsorozatának meghatározása. A továbbiakban X i az X sorozat i hosszú prefixét jelöli X i = (x 1,...,x i ) és hasonlóan jelöljük a prefixeket az Y és Z sorozatokra is. Lemma: Legyen X = (x 1,...,x m ) és Y = (y 1,...,y n ) két sorozat és Z = (z 1,...,z k ) ezek LKR-je. Ekkor: - Ha x m = y n, akkor z k = x m = y n és Z k 1 az X m 1 és Y n 1 sorozatok egy LKR-je. - Ha x m y n, akkor Z az X m 1 és Y vagy az X és Y n 1 sorozatok egy LKR-je. Megoldás dinamikus programozással: Részprobléma: X i és Y j LKR-je. Az LKR hossza legyen c[i,j]. Nyilvánvalóan c[0,j]=c[i, 0]= 0. Rekurzív összefüggés: A lemma alapján 0, ha i = 0 vagy j = 0, c[i, j] = c[i 1, j 1] + 1, ha x i = y j, max{c[i 1, j], c[i, j 1] egyébként, 4

Táblázatkitöltés: c[i,j]-hez használjuk az c[i,j-1] és c[i-1,j] értékeket, ezeknek kell meglenni a c[i,j] érték számításánál. Így a helyes kitöltési sorrend soronként minden sorban a nagyobb j érték felé. A megoldás meghatározását feljegyzéses módszerrel oldjuk meg, S[i,j]-ben feljegyezzük, hogy mi volt az optimális döntés c[i,j] számításakor. LKR for i:=0 to m c[i, 0]:=0 for j:=1 to n c[0,j]:= 0 for i=:1 to m {for j:=1 to n {if x[i]=y[j] then {c[i,j]:=c[i-1,j-1]+1 S[i,j]:=2} else if c[i-1,j]>= c[i,j-1] then {c[i,j]:=c[i-1,j] S[i,j]:=1} else {c[i,j]:=c[i,j-1] S[i,j]:= 0}}} Megoldás meghatározása Ez a szakasz kitölti a c és S táblázatokat, a kiíratás S alapján egy rekurzív algoritmussal megtehető. KIIR(i,j) if i=0 or j=0 then return if S[i,j]=2 then {KIIR(i-1,j-1) Print "x[i]"} else if S[i,j]=1 then KIIR(i-1,j) else KIIR(i,j-1) Példa Határozzuk meg az (a,b,b,a,b,a,b,a) és (b,a,b,a,a,b,a,a,b) sorozatok leghosszabb közös részsorozatát! 5. táblázat. Az c[i,j] értékek táblázata 1 2 3 4 5 5 6 6 6 1 2 3 4 4 5 5 5 6 1 2 3 4 4 4 5 5 5 1 2 3 3 3 4 4 4 5 1 2 2 3 3 3 4 4 4 1 1 2 2 2 3 3 3 3 1 1 2 2 2 2 2 2 2 0 1 1 1 1 1 1 1 1 Tehát az LKR hossza 6. Az LKR-t megkapjuk, ha felírjuk az S táblázatot, vagy visszafejtéssel, ahol az átlós érték növekszik, ott van közös betű. Az i-edik sor j-edik elemének, az X i-edik és az Y j-edik betűje felel meg. Következésképp egy LKR (b, b, a, a, b, a). Hátizsák feladat Egy adott hátizsákba tárgyakat akarunk pakolni. Adott n tárgy minden tárgynak van egy fontossági értéke ( f [i]), és egy súlya (s[i]), a hátizsákba maximum összesen S súlyt pakolhatunk. Az s[i] és S értékek egészek. Szeretnénk 5

úgy választani tárgyakat, hogy az összfontosság maximális legyen. Tehát feladatunk, hogy kiválasszuk a tárgyaknak olyan halmazai közül, amelyekre az összsúly nem haladja meg S-t azt, amelyre maximális az összfontosság. Definiáljuk az F(i,W) függvényt, minden i = 1,...,n, W = 0,...,S értékre. Ez a függvény azon hátizsák probléma optimális függvényértékét adja meg, amelyben a tárgyak listája az első i tárgyat tartalmazza, és a hátizsák mérete W. Ekkor a kezdeti értékekre F(1,W) = f [1], ha s 1 W és 0 különben. Másrészt a következő rekurzió teljesül: F(i + 1,W) = max{f(i,w), f [i + 1] + F(i,W s[i + 1])}, ha s[i + 1] W. Továbbá F(i + 1,W) = F(i,W), ha s[i + 1] > W, A rekurzió valóban fennáll. A részprobléma optimális megoldásában vagy szerepel az i + 1-edik tárgy vagy nem, és ezen két eset maximuma adja az optimális célfüggvényértéket. Hatizsak for x:=0 to s[1]-1 F[x,1]:=0 for x:=s[1] to S F[x,1]:=f[1] for i:=2 to n {for x:=0 to S {F[x][i]:= F[x][i-1] if (s[i]<=x and F[x][i]<F[x-s[i]][i-1]+f[i]) then F[x][i]:=F[x-s[i]][i-1]+f[i]}} KIIR while(f[x][i]>0) {while (i>=1 and F[x][i]==F[x][i-1]) {i=i-1} print "i" x:=x-s[i] i:=i-1} Példa: A tárgyak (súly, fontosság) párokban (4,6) (3,5) (2,3) (2,3) a hátizsák kapacitása 8. 6. táblázat. A partíció algoritmus teljes táblázata 0 0 3 5 6 8 9 11 12 0 0 3 5 6 8 9 11 11 0 0 0 5 6 6 6 11 11 0 0 0 0 6 6 6 6 6 Megoldás: 4,3,1. Kérdések Partíció rekurziómemorizálással Partíció négyzetes táblázatkitöltéssel Mátrixszorzás (KIIR is) Leghosszabb Közös Részsorozat (KIIR is) 6

Hátizsák feladat (KIIR is) Szorgalmi feladat Adott egy k n-es tábla. Minden mezőre meg van adva egy c i j pozitív szám, ami a mezőről begyűjthető érték. Egy játékos a bal alsó sarokból szeretne eljutni a jobb felső sarokba úgy, hogy csak jobbra vagy felfelé léphet szomszédos mezőre. Az útja során, összegyűjtheti a mezőkről az értékeket. Továbbá egyetlen alkalommal megduplázhatja azt az értéket, amit a mezőről begyűjtött. Adjunk egy dinamikus programozási algoritmus, ami meghatározza mi az az útvonal, amivel a maximális összértéket tudja összegyűjteni. Beküldés: cimreh@inf.u-szeged.hu, Pszeudókod vagy forrás+magyarázat első két megoldó 15-15 pont harmadik, negyedik megoldó 10-10 pont ötödik hatodik megoldó 5-5 pont A szerzett plusszpontok a vizsga minimumkövetelményébe nem számítanak bele. 7