Programozás I. 1. előadás: Algoritmusok alapjai. Sergyán Szabolcs
|
|
- Csaba Soós
- 8 évvel ezelőtt
- Látták:
Átírás
1 Programozás I. 1. előadás: Algoritmusok alapjai Sergyán Szabolcs Óbudai Egyetem Neumann János Informatikai Kar Alkalmazott Informatikai Intézet szeptember 7. Sergyán (OE NIK) Programozás I szeptember 7. 1 / 47
2 Tartalom 1 Algoritmus fogalma 2 Változók, típusok és kifejezések 3 Tömbök 4 Vezérlési szerkezetek 5 Algoritmusok leírása pszeudokóddal 6 Hatékonyság, futási idő elemzése Sergyán (OE NIK) Programozás I szeptember 7. 2 / 47
3 Tartalom 1 Algoritmus fogalma 2 Változók, típusok és kifejezések 3 Tömbök 4 Vezérlési szerkezetek 5 Algoritmusok leírása pszeudokóddal 6 Hatékonyság, futási idő elemzése Sergyán (OE NIK) Programozás I szeptember 7. 3 / 47
4 1. példa Autómosás 1 Előmosás. Az autót mosószeres lével bespriccelik. 2 Kefés mosás. A forgó kefék letisztítják az autót. 3 Öbĺıtés. Az autót tiszta vízzel leöbĺıtik. 4 Szárítás. Az autót levegő áramoltatással megszárítják. Egymást követő utasítások sorozata. Sergyán (OE NIK) Programozás I szeptember 7. 4 / 47
5 2. példa Haladó autómosás 1 Ha aktívhabos mosásra fizettünk elő, akkor az autót bespriccelik aktív habbal. Különben csak mosószeres lével spriccelik be az autót. 2 Ha alváz mosásra is előfizettünk, akkor az alvázat is végigspriccelik aktív habbal. 3 Ha kerékmosásra előfizettünk, akkor forgó kefék letisztítják az autót, a kerekeknél pedig speciális keréktisztító kefék mossák a kerekeket. Különben csak a forgó kefék letisztítják az autót. 4 Az autót tiszta vízzel leöbĺıtik. 5 Ha előfizettünk viaszvédelemre, akkor az autót forró viasz réteggel bevonják. 6 Az autót levegőáramoltatással megszárítják. Megjelennek döntési pontok, ahol elágazhat a végrehajtás. Sergyán (OE NIK) Programozás I szeptember 7. 5 / 47
6 Euklideszi algoritmus Két pozitív egész szám legnagyobb közös osztója 1 Adott két pozitív egész szám, jelöljük ezeket m-mel és n-nel. A kettő közül legyen m a nagyobbik. 2 Osszuk el m-et n-nel, az osztás maradékát jelöljük r-rel. 3 Ha r értéke 0, azaz m osztható n-nel, akkor az algoritmus végére értünk. Ilyenkor a két szám legnagyobb közös osztója az n értékével egyezik meg, az algoritmus pedig befejeződik. 4 Ha r értéke nem 0, akkor m-be tároljuk el az n jelenlegi értékét, n-be pedig az r értékét. Majd ugorjunk vissza a 2. pontra. Egyes lépések többször is végrehajtásra kerülnek. Sergyán (OE NIK) Programozás I szeptember 7. 6 / 47
7 Euklideszi algoritmus Két pozitív egész szám legnagyobb közös osztója 1 Adott két pozitív egész szám, jelöljük ezeket m-mel és n-nel. A kettő közül legyen m a nagyobbik. 2 Osszuk el m-et n-nel, az osztás maradékát jelöljük r-rel. 3 Ha r értéke 0, azaz m osztható n-nel, akkor az algoritmus végére értünk. Ilyenkor a két szám legnagyobb közös osztója az n értékével egyezik meg, az algoritmus pedig befejeződik. Konkrét példa m n r Ha r értéke nem 0, akkor m-be tároljuk el az n jelenlegi értékét, n-be pedig az r értékét. Majd ugorjunk vissza a 2. pontra. Sergyán (OE NIK) Programozás I szeptember 7. 7 / 47
8 Algoritmus fogalma Mi az algoritmus? Az algoritmus egy olyan gép, amely valamilyen bemenetekből meghatározott lépéseken keresztül előálĺıt valamilyen kimenetet. Bemenetek: Az algoritmus elején már ismertek. Kimenetek: A bemenetek által egyértelműen meghatározottak. Az algoritmus működése jól meghatározott, azaz determinisztikus. Az algoritmus egyértelmű, jól definiált lépésekből áll, melyek száma minden esetben véges. Sergyán (OE NIK) Programozás I szeptember 7. 8 / 47
9 Algoritmus alkotás Legfontosabb lépések A folyamatot elemi lépésekre bontjuk. Figyelembe vesszük az összes felmerülő lehetőséget. Ügyelünk, hogy az algoritmus véges sok lépésben véget érjen. Sergyán (OE NIK) Programozás I szeptember 7. 9 / 47
10 Tartalom 1 Algoritmus fogalma 2 Változók, típusok és kifejezések 3 Tömbök 4 Vezérlési szerkezetek 5 Algoritmusok leírása pszeudokóddal 6 Hatékonyság, futási idő elemzése Sergyán (OE NIK) Programozás I szeptember / 47
11 Változók Mi az a változó? Az algoritmusban használt értékeket tárolni kell az algoritmus futása során. Változók a bemenetek, a kimenetek és az algoritmus megvalósításához szükséges lokális változók. Minden változónak van neve, amellyel egyértelműen tudunk rá hivatkozni. Minden változónak van típusa is. Sergyán (OE NIK) Programozás I szeptember / 47
12 Típusok Algoritmus leírásnál használt típusok Egészek (pszeudokódban jelölés: egész) Logikaiak (pszeudokódban jelölés: logikai) Általános típus (pszeudokódban jelölés: T) Sergyán (OE NIK) Programozás I szeptember / 47
13 Értékadás Az a változónak értékül adjuk az 5-öt: a 5 Az értékadás bal oldalán egyetlen változó állhat. A jobb oldalon egy érték, egy változó vagy egy kifejezés állhat. Mindig a baloldali változó kapja meg a jobboldali értéket, visszafelé nem történik értékadás. Sergyán (OE NIK) Programozás I szeptember / 47
14 Csere Az a és b változó megcserélésének lépései: segéd a a b b segéd Rövidebb jelölés: a b Sergyán (OE NIK) Programozás I szeptember / 47
15 Kifejezések Mi az a kifejezés? Számkifejezésben számokat tartalmazó változók, konkrét számértékek és ezeket összekapcsoló matematikai műveletek szerepelhetnek. Példa: bal jobb + 3, 2 ahol bal és jobb egy-egy változó. A számkifejezések kiértékelése a matematikában megismert szabályok szerint történik. Sergyán (OE NIK) Programozás I szeptember / 47
16 Logikai típus Értékek és műveletek Két lehetséges érték: igaz hamis Műveletek: Negálás: És kapcsolat: Vagy kapcsolat: Sergyán (OE NIK) Programozás I szeptember / 47
17 Logikai típus Negálás l logikai értéke hamis igaz l logikai értéke igaz hamis És valamint vagy kapcsolat l 1 log. értéke l 2 log. értéke l 1 l 2 log. értéke l 1 l 2 log. értéke hamis hamis hamis hamis hamis igaz hamis igaz igaz hamis hamis igaz igaz igaz igaz igaz Sergyán (OE NIK) Programozás I szeptember / 47
18 Logikai típus Rövidzár kiértékelés Ha egy és kapcsolat első tagja hamis, akkor a második tag már nem is kerül kiértékelésre, mert a teljes és kapcsolat hamis lesz. Ha egy vagy kapcsolat első tagja igaz, akkor a második tag már nem is kerül kiértékelésre, mert a teljes vagy kapcsolat igaz lesz. Sergyán (OE NIK) Programozás I szeptember / 47
19 Tartalom 1 Algoritmus fogalma 2 Változók, típusok és kifejezések 3 Tömbök 4 Vezérlési szerkezetek 5 Algoritmusok leírása pszeudokóddal 6 Hatékonyság, futási idő elemzése Sergyán (OE NIK) Programozás I szeptember / 47
20 Tömbök Mi a tömb? Több azonos típusú értéket lehet egy változóban eltárolni. A tömb elemeire indexeléssel hivatkozunk. A harmadik elem elérése: x[3]. Az indexelés 1-től indul. x: Tömb létrehozása x Létrehoz(egész)[8] Sergyán (OE NIK) Programozás I szeptember / 47
21 Kétdimenziós tömbök Példa Elemre hivatkozás: x[2, 5] Kétdimenziós tömb létrehozása x Létrehoz(egész)[4, 6] Sergyán (OE NIK) Programozás I szeptember / 47
22 Tartalom 1 Algoritmus fogalma 2 Változók, típusok és kifejezések 3 Tömbök 4 Vezérlési szerkezetek 5 Algoritmusok leírása pszeudokóddal 6 Hatékonyság, futási idő elemzése Sergyán (OE NIK) Programozás I szeptember / 47
23 Szekvencia Utasítások egymás utáni végrehajtása x Létrehoz(egész)[3] x[1] 5 x[2] 8 x[3] 11 Sergyán (OE NIK) Programozás I szeptember / 47
24 Elágazás Utasítás feltételes végrehajtása ha a < 0 akkor a a elágazás vége b a Sergyán (OE NIK) Programozás I szeptember / 47
25 Elágazás Kétirányú elágazás ha a < 0 akkor b a különben b a elágazás vége Sergyán (OE NIK) Programozás I szeptember / 47
26 Elágazás Többirányú elágazás ha a > 0 akkor b a különben ha a < 0 akkor b a különben b 0 elágazás vége Sergyán (OE NIK) Programozás I szeptember / 47
27 Ciklus Elöltesztelős ciklus ciklus amíg feltétel utasítások ciklus vége Példa ciklus amíg r 0 m n n r r m mod n ciklus vége Sergyán (OE NIK) Programozás I szeptember / 47
28 Ciklus Hátultesztelős ciklus ciklus utasítások amíg feltétel Sergyán (OE NIK) Programozás I szeptember / 47
29 Ciklus Számlálós ciklus ciklus ciklusv áltozó kezdetiérték-től v ég érték-ig utasítások ciklus vége Példa x Létrehoz(egész)[5] ciklus i 1-től 5-ig x[i] i 2 ciklus vége Sergyán (OE NIK) Programozás I szeptember / 47
30 Tartalom 1 Algoritmus fogalma 2 Változók, típusok és kifejezések 3 Tömbök 4 Vezérlési szerkezetek 5 Algoritmusok leírása pszeudokóddal 6 Hatékonyság, futási idő elemzése Sergyán (OE NIK) Programozás I szeptember / 47
31 Strukturált programozás Strukturált programnak tekintjük azokat a programokat, amelyek csak a megengedett elemi programokat tartalmazzák a megengedett programkonstrukciók (vezérlési szerkezetek) alkalmazásával. Elemi programok üres program értékadás (állapot változtatás) jele: Megengedett konstrukciók szekvencia elágazás ciklus Bizonyítható, hogy a fenti szabályok megtartásával minden algoritmussal megoldható feladatra adható is megoldás. Sergyán (OE NIK) Programozás I szeptember / 47
32 Moduláris programozás Az elkészítendő programot egyetlen utasítással szeretnénk megoldani. Ha ez nem sikerül, akkor több utasítással próbálkozunk, melyek egyes részfeladatokat valósítanak meg. Addig folytatjuk ezt a részfeladatokra bontást, míg minden részfeladatot sikerül megvalósítani elemi utasítások felhasználásával. Összefoglalva: A teljes feladatot részekre bontjuk, majd ezeket a visszavezetés módszerével megoldjuk. Sergyán (OE NIK) Programozás I szeptember / 47
33 Függvények vs. eljárások Függvény Eljárás Egy konkrét algoritmust valósít meg. Más függvények vagy eljárások meghívhatják. Vannak bemenetei. Van visszatérési értéke (kimenete). Ezt a vissza kulcsszóval adjuk meg. Egy konkrét algoritmust valósít meg. Más függvények vagy eljárások meghívhatják. Vannak bemenetei. Kimenete csak paramétereken keresztül lehet. Ehhez címszerint adjuk át a paramétert. Sergyán (OE NIK) Programozás I szeptember / 47
34 Euklideszi algoritmus Függvénnyel megvalósítva Bemenet: m egész, n egész Kimenet: n egész 1: függvény LNKO(m, n) 2: r m mod n 3: ciklus amíg r 0 4: m n 5: n r 6: r m mod n 7: ciklus vége 8: vissza n 9: függvény vége Sergyán (OE NIK) Programozás I szeptember / 47
35 Euklideszi algoritmus Eljárással megvalósítva Bemenet: m egész, n egész Kimenet: n egész 1: eljárás LNKO(m, címszerint n) 2: r m mod n 3: ciklus amíg r 0 4: m n 5: n r 6: r m mod n 7: ciklus vége 8: eljárás vége Sergyán (OE NIK) Programozás I szeptember / 47
36 Függvény hívása Relatív prím vizsgálat Bemenet: x egész tömb, n egész (tömb mérete), value egész Kimenet: y logikai tömb 1: függvény RelatívPrímVizsgálat(x, n, value) 2: y Létrehoz(logikai)[n] 3: ciklus i 1-től n-ig 4: ha LNKO(x[i], value) = 1 akkor 5: y[i] igaz 6: különben 7: y[i] hamis 8: elágazás vége 9: ciklus vége 10: függvény vége Sergyán (OE NIK) Programozás I szeptember / 47
37 Tartalom 1 Algoritmus fogalma 2 Változók, típusok és kifejezések 3 Tömbök 4 Vezérlési szerkezetek 5 Algoritmusok leírása pszeudokóddal 6 Hatékonyság, futási idő elemzése Sergyán (OE NIK) Programozás I szeptember / 47
38 Algoritmusokkal kapcsolatos elvárások Mikor jó egy algoritmus? Megbízható: Helyesen működik. Kiszámítható: Adott bemenet esetén mindig ugyanazt a kimenetet szolgáltatja. Egyszerű: Könnyen megérthető. Hatékony: Kevés memória igénye van. Kevés a futási ideje. Sergyán (OE NIK) Programozás I szeptember / 47
39 Előadásra járó hallgatók számának meghatározása Hányan vannak itt a teremben? Hogyan tudnánk ezt hatékonyan megszámolni? Sergyán (OE NIK) Programozás I szeptember / 47
40 Szó keresése szótárban Hogyan tudunk hatékonyan szót keresni egy szótárban? Sergyán (OE NIK) Programozás I szeptember / 47
41 Algoritmus lépésszáma Egy algoritmus lépésszáma alatt azt értjük, hogy hány elemi műveletet (értékadás, összehasonĺıtás, stb.) kell végrehajtani adott bemenet mellett. Egy algoritmus futási ideje függ az algoritmust megvalósító programtól, a programozási nyelvtől, a számítógéptől, stb. Algoritmuselméletben a futási időt a lépésszámmal jellemezzük. Sergyán (OE NIK) Programozás I szeptember / 47
42 Futási idő Hány lépésben fut le az algoritmus? Bemenet: x egész tömb, n egész Kimenet: db egész 1: függvény NullátAdóElempárokSzáma(x, n) 2: db 0 3: ciklus i 1-től (n 1)-ig 4: ciklus j (i + 1)-től n-ig 5: ha x[i] + x[j] = 0 akkor 6: db db + 1 7: elágazás vége 8: ciklus vége 9: ciklus vége 10: vissza db 11: függvény vége Sergyán (OE NIK) Programozás I szeptember / 47
43 Futási idő Feltétel kiértékelések száma (n 1) + (n 2) = (n 1) (n 1) = n (n 1) 2 Értékadások száma Legjobb esetben: 0-szor Legrosszabb esetben: n(n 1) 2 -szer Algoritmus futási ideje O ( n 2) Sergyán (OE NIK) Programozás I szeptember / 47
44 Futási idő anaĺızisének fajtái Legrosszab eset anaĺızis T (n): a maximális futási idő, amely bármely n elemű sorozat esetén a rendezéshez legfeljebb szükséges Átlagos eset anaĺızis T (n): a várható futási idő, amely az n elemű sorozatok rendezéséhez szükséges Legjobb eset anaĺızis Magunkat verjük át, ha ezzel foglalkozunk Sergyán (OE NIK) Programozás I szeptember / 47
45 Futási idő Futási idők összehasonĺıtása 800 T (n) n2 n log 2 n n Nagy ordó jelölés Azt mondjuk, hogy a T (n) futási idő O (f (n))-es, ha létezik olyan c konstans, hogy elég nagy n értékek esetén T (n) c f (n). Sergyán (OE NIK) Programozás I szeptember / 47
46 Futási idő Gyakran előforduló nagyságrendek Futási idő nagyságrendje Futási idő nagyságrendjének elnevezése O(1) Konstans O(log n) Logaritmikus O(n) Lineáris O(n log n) Logaritmetikus O(n 2 ) Négyzetes O(n 3 ) Köbös O(2 n ) Exponenciális Sergyán (OE NIK) Programozás I szeptember / 47
47 Futási idő Gyakori nagyságrendek T (n) n O(log n) Sergyán (OE NIK) Programozás I szeptember / 47
48 Futási idő Gyakori nagyságrendek T (n) n O(log n) O(n) Sergyán (OE NIK) Programozás I szeptember / 47
49 Futási idő Gyakori nagyságrendek T (n) n O(log n) O(n) O(n log n) Sergyán (OE NIK) Programozás I szeptember / 47
50 Futási idő Gyakori nagyságrendek T (n) 10,000 8,000 6,000 4,000 2, n O(log n) O(n) O(n log n) O(n 2 ) Sergyán (OE NIK) Programozás I szeptember / 47
Programozás I. Sergyán Szabolcs Óbudai Egyetem Neumann János Informatikai Kar szeptember 10.
Programozás I. 1. előadás Sergyán Szabolcs sergyan.szabolcs@nik.uni-obuda.hu Óbudai Egyetem Neumann János Informatikai Kar 2012. szeptember 10. Sergyán (OE NIK) Programozás I. 2012. szeptember 10. 1 /
Programozás I. Sergyán Szabolcs Óbudai Egyetem Neumann János Informatikai Kar szeptember 10.
Programozás I. 1. előadás Sergyán Szabolcs sergyan.szabolcs@nik.uni-obuda.hu Óbudai Egyetem Neumann János Informatikai Kar 2012. szeptember 10. Sergyán (OE NIK) Programozás I. 2012. szeptember 10. 1 /
Algoritmusok, adatszerkezetek, objektumok
Algoritmusok, adatszerkezetek, objektumok 1. előadás Sergyán Szabolcs sergyan.szabolcs@nik.uni-obuda.hu Óbudai Egyetem Neumann János Informatikai Kar 2011. szeptember 14. Sergyán (OE NIK) AAO 01 2011.
Összetett programozási tételek
Összetett programozási tételek 3. előadás Sergyán Szabolcs sergyan.szabolcs@nik.uni-obuda.hu Óbudai Egyetem Neumann János Informatikai Kar 2011. szeptember 19. Sergyán (OE NIK) AAO 03 2011. szeptember
Programozás I. Egyszerű programozási tételek. Sergyán Szabolcs sergyan.szabolcs@nik.uni-obuda.hu
Programozás I. 3. előadás Egyszerű programozási tételek Sergyán Szabolcs sergyan.szabolcs@nik.uni-obuda.hu Óbudai Egyetem Neumann János Informatikai Kar Alkalmazott Informatikai Intézet 2015. szeptember
1. Alapfogalmak Algoritmus Számítási probléma Specifikáció Algoritmusok futási ideje
1. Alapfogalmak 1.1. Algoritmus Az algoritmus olyan elemi műveletekből kompozíciós szabályok szerint felépített összetett művelet, amelyet megadott feltételt teljesítő bemeneti adatra végrehajtva, a megkívánt
Egyszerű programozási tételek
Egyszerű programozási tételek 2. előadás Sergyán Szabolcs sergyan.szabolcs@nik.uni-obuda.hu Óbudai Egyetem Neumann János Informatikai Kar 2011. szeptember 15. Sergyán (OE NIK) AAO 02 2011. szeptember 15.
Programozás I. Egyszerű programozási tételek. Sergyán Szabolcs
Programozás I. 3. előadás Egyszerű programozási tételek Sergyán Szabolcs sergyan.szabolcs@nik.uni-obuda.hu Óbudai Egyetem Neumann János Informatikai Kar Alkalmazott Informatikai Intézet 2015. szeptember
Rekurzív algoritmusok
Rekurzív algoritmusok 11. előadás Sergyán Szabolcs sergyan.szabolcs@nik.uni-obuda.hu Óbudai Egyetem Neumann János Informatikai Kar 2011. november 14. Sergyán (OE NIK) AAO 11 2011. november 14. 1 / 32 Rekurzív
Algoritmusok Tervezése. 6. Előadás Algoritmusok 101 Dr. Bécsi Tamás
Algoritmusok Tervezése 6. Előadás Algoritmusok 101 Dr. Bécsi Tamás Mi az algoritmus? Lépések sorozata egy feladat elvégzéséhez (legáltalánosabban) Informálisan algoritmusnak nevezünk bármilyen jól definiált
Algoritmusok. Dr. Iványi Péter
Algoritmusok Dr. Iványi Péter Egyik legrégebbi algoritmus i.e. IV század, Alexandria, Euklidész két természetes szám legnagyobb közös osztójának meghatározása Tegyük fel, hogy a és b pozitív egész számok
Felvételi tematika INFORMATIKA
Felvételi tematika INFORMATIKA 2016 FEJEZETEK 1. Természetes számok feldolgozása számjegyenként. 2. Számsorozatok feldolgozása elemenként. Egydimenziós tömbök. 3. Mátrixok feldolgozása elemenként/soronként/oszloponként.
Webprogramozás szakkör
Webprogramozás szakkör Előadás 5 (2012.04.09) Programozás alapok Eddig amit láttunk: Programozás lépései o Feladat leírása (specifikáció) o Algoritmizálás, tervezés (folyamatábra, pszeudokód) o Programozás
Bánsághi Anna 2014 Bánsághi Anna 1 of 68
IMPERATÍV PROGRAMOZÁS Bánsághi Anna anna.bansaghi@mamikon.net 3. ELŐADÁS - PROGRAMOZÁSI TÉTELEK 2014 Bánsághi Anna 1 of 68 TEMATIKA I. ALAPFOGALMAK, TUDOMÁNYTÖRTÉNET II. IMPERATÍV PROGRAMOZÁS Imperatív
Dr. Schuster György február / 32
Algoritmusok és magvalósítások Dr. Schuster György OE-KVK-MAI schuster.gyorgy@kvk.uni-obuda.hu 2015. február 10. 2015. február 10. 1 / 32 Algoritmus Alapfogalmak Algoritmus Definíció Algoritmuson olyan
A félév során előkerülő témakörök
A félév során előkerülő témakörök rekurzív algoritmusok rendező algoritmusok alapvető adattípusok, adatszerkezetek, és kapcsolódó algoritmusok dinamikus programozás mohó algoritmusok gráf algoritmusok
Nagyságrendek. Kiegészítő anyag az Algoritmuselmélet tárgyhoz. Friedl Katalin BME SZIT február 1.
Nagyságrendek Kiegészítő anyag az Algoritmuselmélet tárgyhoz (a Rónyai Ivanyos Szabó: Algoritmusok könyv mellé) Friedl Katalin BME SZIT friedl@cs.bme.hu 018. február 1. Az O, Ω, Θ jelölések Az algoritmusok
A C# programozási nyelv alapjai
A C# programozási nyelv alapjai Tisztán objektum-orientált Kis- és nagybetűket megkülönbözteti Ötvözi a C++, Delphi, Java programozási nyelvek pozitívumait.net futtatókörnyezet Visual Studio fejlesztőkörnyezet
ALGORITMIKUS SZERKEZETEK ELÁGAZÁSOK, CIKLUSOK, FÜGGVÉNYEK
ALGORITMIKUS SZERKEZETEK ELÁGAZÁSOK, CIKLUSOK, FÜGGVÉNYEK 1. ELÁGAZÁSOK ÉS CIKLUSOK SZERVEZÉSE Az adatszerkezetek mellett a programok másik alapvető fontosságú építőkövei az ún. algoritmikus szerkezetek.
Java programozási nyelv
Java programozási nyelv 2. rész Vezérlő szerkezetek Nyugat-Magyarországi Egyetem Faipari Mérnöki Kar Informatikai Intézet Soós Sándor 2005. szeptember A Java programozási nyelv Soós Sándor 1/23 Tartalomjegyzék
Rendezések. Sergyán Szabolcs Óbudai Egyetem Neumann János Informatikai Kar október 24.
Rendezések 8. előadás Sergyán Szabolcs sergyan.szabolcs@nik.uni-obuda.hu Óbudai Egyetem Neumann János Informatikai Kar 2011. október 24. Sergyán (OE NIK) AAO 08 2011. október 24. 1 / 1 Felhasznált irodalom
Rekurzió. Működése, programtranszformációk. Programozás II. előadás. Szénási Sándor.
Rekurzió Működése, programtranszformációk előadás http://nik.uni-obuda.hu/prog2 Szénási Sándor szenasi.sandor@nik.uni-obuda.hu Óbudai Egyetem,Neumann János Informatikai Kar Rekurzió Rekurzió alapjai Rekurzív
Programozási tételek. PPT 2007/2008 tavasz.
Programozási tételek szenasi.sandor@nik.bmf.hu PPT 2007/2008 tavasz http://nik.bmf.hu/ppt 1 Témakörök Strukturált programozás paradigma Alapvető programozási tételek Összetett programozási tételek Programozási
Programozási nyelvek a közoktatásban alapfogalmak I. előadás
Programozási nyelvek a közoktatásban alapfogalmak I. előadás Szempontok Programozási nyelvek osztályozása Felhasználói kör (amatőr, professzionális) Emberközelség (gépi nyelvektől a természetes nyelvekig)
Programozás II. előadás
Nem összehasonlító rendezések Nem összehasonlító rendezések Programozás II. előadás http://nik.uni-obuda.hu/prog2 Szénási Sándor Óbudai Egyetem,Neumann János Informatikai Kar Programozás II. 2 Rendezés
Készítette: Nagy Tibor István Felhasznált irodalom: Kotsis Domokos: OOP diasor Zsakó L., Szlávi P.: Mikrológia 19.
Készítette: Nagy Tibor István Felhasznált irodalom: Kotsis Domokos: OOP diasor Zsakó L., Szlávi P.: Mikrológia 19. Programkészítés Megrendelői igények begyűjtése Megoldás megtervezése (algoritmuskészítés)
Programozási nyelvek 6. előadás
Programozási nyelvek 6. előadás Szempontok Programozási nyelvek osztályozása Felhasználói kör (amatőr, professzionális) Emberközelség (gépi nyelvektől a természetes nyelvekig) Számítási modell (hogyan
Függvények növekedési korlátainak jellemzése
17 Függvények növekedési korlátainak jellemzése A jellemzés jól bevált eszközei az Ω, O, Θ, o és ω jelölések. Mivel az igények általában nemnegatívak, ezért az alábbi meghatározásokban mindenütt feltesszük,
Hatékonyság 1. előadás
Hatékonyság 1. előadás Mi a hatékonyság Bevezetés A hatékonyság helye a programkészítés folyamatában: csak HELYES programra Erőforrásigény: a felhasználó és a fejlesztő szempontjából A hatékonyság mérése
Bevezetés az informatikába
Bevezetés az informatikába 6. előadás Dr. Istenes Zoltán Eötvös Loránd Tudományegyetem Informatikai Kar Programozáselmélet és Szoftvertechnológiai Tanszék Matematikus BSc - I. félév / 2008 / Budapest Dr.
5. előadás. Programozás-elmélet. Programozás-elmélet 5. előadás
Elemi programok Definíció Az S A A program elemi, ha a A : S(a) { a, a, a, a,..., a, b b a}. A definíció alapján könnyen látható, hogy egy elemi program tényleg program. Speciális elemi programok a kövekezők:
Adatszerkezetek 2. Dr. Iványi Péter
Adatszerkezetek 2. Dr. Iványi Péter 1 Hash tábla A bináris fáknál O(log n) a legjobb eset a keresésre. Ha valamilyen közvetlen címzést használunk, akkor akár O(1) is elérhető. A hash tábla a tömb általánosításaként
Előfeltétel: legalább elégséges jegy Diszkrét matematika II. (GEMAK122B) tárgyból
ÜTEMTERV Programozás-elmélet c. tárgyhoz (GEMAK233B, GEMAK233-B) BSc gazdaságinformatikus, programtervező informatikus alapszakok számára Óraszám: heti 2+0, (aláírás+kollokvium, 3 kredit) 2019/20-es tanév
Programozás alapjai (ANSI C)
Programozás alapjai (ANSI C) 1. Előadás vázlat A számítógép és programozása Dr. Baksáné dr. Varga Erika adjunktus Miskolci Egyetem, Informatikai Intézet Általános Informatikai Intézeti Tanszék www.iit.uni-miskolc.hu
A programozás alapjai előadás. Amiről szólesz: A tárgy címe: A programozás alapjai
A programozás alapjai 1 1. előadás Híradástechnikai Tanszék Amiről szólesz: A tárgy címe: A programozás alapjai A számítógép részegységei, alacsony- és magasszintű programnyelvek, az imperatív programozási
A programozás alapjai 1 Rekurzió
A programozás alapjai Rekurzió. előadás Híradástechnikai Tanszék - preorder (gyökér bal gyerek jobb gyerek) mentés - visszaállítás - inorder (bal gyerek gyökér jobb gyerek) rendezés 4 5 6 4 6 7 5 7 - posztorder
Változók. Mennyiség, érték (v. objektum) szimbolikus jelölése, jelentése Tulajdonságai (attribútumai):
Javascript Változók Mennyiség, érték (v. objektum) szimbolikus jelölése, jelentése Tulajdonságai (attribútumai): Név Érték Típus Memóriacím A változó értéke (esetleg más attribútuma is) a program futása
Változók. Mennyiség, érték (v. objektum) szimbolikus jelölése, jelentése Tulajdonságai (attribútumai):
Python Változók Mennyiség, érték (v. objektum) szimbolikus jelölése, jelentése Tulajdonságai (attribútumai): Név Érték Típus Memóriacím A változó értéke (esetleg más attribútuma is) a program futása alatt
Teljesítmény Mérés. Tóth Zsolt. Miskolci Egyetem. Tóth Zsolt (Miskolci Egyetem) Teljesítmény Mérés / 20
Teljesítmény Mérés Tóth Zsolt Miskolci Egyetem 2013 Tóth Zsolt (Miskolci Egyetem) Teljesítmény Mérés 2013 1 / 20 Tartalomjegyzék 1 Bevezetés 2 Visual Studio Kód metrikák Performance Explorer Tóth Zsolt
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.
Algoritmus Az algoritmus olyan elemi műveletekből kompozíciós szabályok szerint felépített összetett művelet, amelyet megadott feltételt teljesítő bemeneti adatra végrehajtva, a megkívánt kimeneti adatot
Rendezések. A rendezési probléma: Bemenet: Kimenet: n számot tartalmazó (a 1,a 2,,a n ) sorozat
9. Előadás Rendezések A rendezési probléma: Bemenet: n számot tartalmazó (a 1,a 2,,a n ) sorozat Kimenet: a bemenő sorozat olyan (a 1, a 2,,a n ) permutációja, hogy a 1 a 2 a n 2 Rendezések Általánosabban:
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.
Algoritmus Az algoritmus olyan elemi műveletekből kompozíciós szabályok szerint felépített összetett művelet, amelyet megadott feltételt teljesítő bemeneti adatra végrehajtva, a megkívánt kimeneti adatot
Algoritmizálás, adatmodellezés tanítása 6. előadás
Algoritmizálás, adatmodellezés tanítása 6. előadás Tesztelési módszerek statikus tesztelés kódellenőrzés szintaktikus ellenőrzés szemantikus ellenőrzés dinamikus tesztelés fekete doboz módszerek fehér
Rekurzió. Dr. Iványi Péter
Rekurzió Dr. Iványi Péter 1 Függvényhívás void f3(int a3) { printf( %d,a3); } void f2(int a2) { f3(a2); a2 = (a2+1); } void f1() { int a1 = 1; int b1; b1 = f2(a1); } 2 Függvényhívás void f3(int a3) { printf(
Programozás I. Metódusok C#-ban Egyszerű programozási tételek. Sergyán Szabolcs sergyan.szabolcs@nik.uni-obuda.hu
Programozás I. 3. előadás Tömbök a C#-ban Metódusok C#-ban Egyszerű programozási tételek Sergyán Szabolcs sergyan.szabolcs@nik.uni-obuda.hu Óbudai Egyetem Neumann János Informatikai Kar Szoftvertechnológia
9. előadás. Programozás-elmélet. Programozási tételek Elemi prog. Sorozatszámítás Eldöntés Kiválasztás Lin. keresés Megszámolás Maximum.
Programozási tételek Programozási feladatok megoldásakor a top-down (strukturált) programtervezés esetén három vezérlési szerkezetet használunk: - szekvencia - elágazás - ciklus Eddig megismertük az alábbi
BASH script programozás II. Vezérlési szerkezetek
06 BASH script programozás II. Vezérlési szerkezetek Emlékeztető Jelölésbeli különbség van parancs végrehajtása és a parancs kimenetére való hivatkozás között PARANCS $(PARANCS) Jelölésbeli különbség van
BABEŞ BOLYAI TUDOMÁNYEGYETEM MATEMATIKA ÉS INFORMATIKA KAR BBTE Matek-Infó verseny 1. tételsor INFORMATIKA írásbeli. A versenyzők figyelmébe:
BABEŞ BOLYAI TUDOMÁNYEGYETEM MATEMATIKA ÉS INFORMATIKA KAR BBTE Matek-Infó verseny 1. tételsor INFORMATIKA írásbeli A versenyzők figyelmébe: 1. A tömböket 1-től kezdődően indexeljük. 2. A rácstesztekre
Programozási Módszertan definíciók, stb.
Programozási Módszertan definíciók, stb. 1. Bevezetés Egy adat típusát az adat által felvehető lehetséges értékek halmaza (típusérték halmaz, TÉH), és az ezen értelmezett műveletek (típusműveletek) együttesen
Programozás alapjai gyakorlat. 4. gyakorlat Konstansok, tömbök, stringek
Programozás alapjai gyakorlat 4. gyakorlat Konstansok, tömbök, stringek Házi ellenőrzés (f0069) Valósítsd meg a linuxos seq parancs egy egyszerűbb változatát, ami beolvas két egész számot, majd a kettő
Algoritmuselmélet. Bonyolultságelmélet. Katona Gyula Y.
Algoritmuselmélet Bonyolultságelmélet Katona Gyula Y. Számítástudományi és Információelméleti Tanszék Budapesti Műszaki és Gazdaságtudományi Egyetem 12. előadás Katona Gyula Y. (BME SZIT) Algoritmuselmélet
ELEMI PROGRAMOZÁSI TÉTELEK
ELEMI PROGRAMOZÁSI TÉTELEK 1. FELADATMEGOLDÁS PROGRAMOZÁSI TÉTELEKKEL 1.1 A programozási tétel fogalma A programozási tételek típusalgoritmusok, amelyek alkalmazásával garantáltan helyes megoldást adhatunk
Haladó rendezések. PPT 2007/2008 tavasz.
Haladó rendezések szenasi.sandor@nik.bmf.hu PPT 2007/2008 tavasz http://nik.bmf.hu/ppt 1 Témakörök Alapvető összehasonlító rendezések Shell rendezés Kupacrendezés Leszámláló rendezés Radix rendezés Edényrendezés
Objektumorientált Programozás VI.
Objektumorientált Programozás Metódusok Paraméterek átadása Programozási tételek Feladatok VI. ÓE-NIK, 2011 1 Hallgatói Tájékoztató A jelen bemutatóban található adatok, tudnivalók és információk a számonkérendő
Programozási alapismeretek 3. előadás
Programozási alapismeretek 3. előadás Tartalom Ciklusok specifikáció+ algoritmika +kódolás Egy bevezető példa a tömbhöz A tömb Elágazás helyett tömb Konstans tömbök 2/42 Ciklusok Feladat: Határozzuk meg
Eseménykezelés. Szoftvertervezés és -fejlesztés II. előadás. Szénási Sándor.
Eseménykezelés előadás http://nik.uni-obuda.hu/sztf2 Szénási Sándor szenasi.sandor@nik.uni-obuda.hu Óbudai Egyetem,Neumann János Informatikai Kar Függvénymutatókkal Származtatással Interfészekkel Egyéb
I. ALAPALGORITMUSOK. I. Pszeudokódban beolvas n prim igaz minden i 2,gyök(n) végezd el ha n % i = 0 akkor prim hamis
I. ALAPALGORITMUSOK 1. Prímszámvizsgálat Adott egy n természetes szám. Írjunk algoritmust, amely eldönti, hogy prímszám-e vagy sem! Egy számról úgy fogjuk eldönteni, hogy prímszám-e, hogy megvizsgáljuk,
AZ ALGORITMUS. az eredményt szolgáltatja
ALGORITMUSOK AZ ALGORITMUS Az algoritmus problémamegoldásra szolgáló elemi lépések olyan sorozata, amely a következő jellemzőkkel bír: Véges: véges számú lépés után befejeződik, és eredményt szolgáltat
Tartalom Keresés és rendezés. Vektoralgoritmusok. 1. fejezet. Keresés adatvektorban. A programozás alapjai I.
Keresés Rendezés Feladat Keresés Rendezés Feladat Tartalom Keresés és rendezés A programozás alapjai I. Hálózati Rendszerek és Szolgáltatások Tanszék Farkas Balázs, Fiala Péter, Vitéz András, Zsóka Zoltán
Rendezések. Összehasonlító rendezések
Rendezések Összehasonlító rendezések Remdezés - Alapfeladat: Egy A nevű N elemű sorozat elemeinek nagyság szerinti sorrendbe rendezése - Feltételezzük: o A sorozat elemei olyanok, amelyekre a >, relációk
Programozás I. Matematikai lehetőségek Műveletek tömbökkel Egyszerű programozási tételek & gyakorlás V 1.0 OE-NIK,
Programozás I. Matematikai lehetőségek Műveletek tömbökkel Egyszerű programozási tételek & gyakorlás OE-NIK, 2013 1 Hallgatói Tájékoztató A jelen bemutatóban található adatok, tudnivalók és információk
A 2017/2018 tanévi Országos Középiskolai Tanulmányi Verseny első fordulójának feladatai. INFORMATIKA II. (programozás) kategória
Oktatási Hivatal A 2017/2018 tanévi Országos Középiskolai Tanulmányi Verseny első fordulójának feladatai 1. feladat: Repülők (20 pont) INFORMATIKA II. (programozás) kategória Ismerünk városok közötti repülőjáratokat.
Pontműveletek. Sergyán Szabolcs Óbudai Egyetem Neumann János Informatikai Kar február 20.
Pontműveletek Sergyán Szabolcs sergyan.szabolcs@nik.uni-obuda.hu Óbudai Egyetem Neumann János Informatikai Kar 2012. február 20. Sergyán (OE NIK) Pontműveletek 2012. február 20. 1 / 40 Felhasznált irodalom
Keresés és rendezés. A programozás alapjai I. Hálózati Rendszerek és Szolgáltatások Tanszék Farkas Balázs, Fiala Péter, Vitéz András, Zsóka Zoltán
Keresés Rendezés Feladat Keresés és rendezés A programozás alapjai I. Hálózati Rendszerek és Szolgáltatások Tanszék Farkas Balázs, Fiala Péter, Vitéz András, Zsóka Zoltán 2016. november 7. Farkas B., Fiala
Adattípusok, vezérlési szerkezetek. Informatika Szabó Adrienn szeptember 14.
Informatika 1 2011 Második előadás, vezérlési szerkezetek Szabó Adrienn 2011. szeptember 14. Tartalom Algoritmusok, vezérlési szerkezetek If - else: elágazás While ciklus For ciklus Egyszerű típusok Összetett
Ö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.
Összetett programozási tételek Sorozathoz sorozatot relő feladatokkal foglalkozunk. A bemenő sorozatot le kell másolni, s közben az elemekre vonatkozó átalakításokat lehet végezni rajta: Input : n N 0,
Bánsághi Anna 2014 Bánsághi Anna 1 of 33
IMPERATÍV PROGRAMOZÁS Bánsághi Anna anna.bansaghi@mamikon.net 7. ELŐADÁS - ABSZTRAKT ADATTÍPUS 2014 Bánsághi Anna 1 of 33 TEMATIKA I. ALAPFOGALMAK, TUDOMÁNYTÖRTÉNET II. IMPERATÍV PROGRAMOZÁS Imperatív
Vezérlési szerkezetek
Vezérlési szerkezetek Szelekciós ok: if, else, switch If Segítségével valamely ok végrehajtását valamely feltétel teljesülése esetén végezzük el. Az if segítségével valamely tevékenység () végrehajtását
Adatszerkezetek. Nevezetes algoritmusok (Keresések, rendezések)
Adatszerkezetek Nevezetes algoritmusok (Keresések, rendezések) Keresések A probléma általános megfogalmazása: Adott egy N elemű sorozat, keressük meg azt az elemet (határozzuk meg a helyét a sorozatban),
Adatszerkezetek Tömb, sor, verem. Dr. Iványi Péter
Adatszerkezetek Tömb, sor, verem Dr. Iványi Péter 1 Adat Adat minden, amit a számítógépünkben tárolunk és a külvilágból jön Az adatnak két fontos tulajdonsága van: Értéke Típusa 2 Adat típusa Az adatot
Optimalizációs stratégiák 1.
Optimalizációs stratégiák 1. Nyers erő, Oszd meg és uralkodj, Feljegyzéses, Dinamikus, Mohó előadás http://nik.uni-obuda.hu/prog2 Szénási Sándor szenasi.sandor@nik.uni-obuda.hu Óbudai Egyetem,Neumann János
Programozás. (GKxB_INTM021) Dr. Hatwágner F. Miklós február 18. Széchenyi István Egyetem, Gy r
Programozás (GKxB_INTM021) Széchenyi István Egyetem, Gy r 2018. február 18. Minimum és maximumkeresés u s i n g n a m e s p a c e s t d ; i n t main ( ) { c o u t
Bonyolultságelmélet. Monday 26 th September, 2016, 18:50
Bonyolultságelmélet Monday 26 th September, 2016, 18:50 A kiszámítás modelljei 2 De milyen architektúrán polinom? A kiszámításnak számos (matematikai) modellje létezik: Általános rekurzív függvények λ-kalkulus
Pásztor Attila. Algoritmizálás és programozás tankönyv az emeltszintű érettségihez
Pásztor Attila Algoritmizálás és programozás tankönyv az emeltszintű érettségihez 3. ADATTÍPUSOK...26 3.1. AZ ADATOK LEGFONTOSABB JELLEMZŐI:...26 3.2. ELEMI ADATTÍPUSOK...27 3.3. ÖSSZETETT ADATTÍPUSOK...28
Hardver leíró nyelvek (HDL)
Hardver leíró nyelvek (HDL) Benesóczky Zoltán 2004 A jegyzetet a szerzıi jog védi. Azt a BME hallgatói használhatják, nyomtathatják tanulás céljából. Minden egyéb felhasználáshoz a szerzı belegyezése szükséges.
Adatszerkezetek 1. Dr. Iványi Péter
Adatszerkezetek 1. Dr. Iványi Péter 1 Adat Adat minden, amit a számítógépünkben tárolunk és a külvilágból jön Az adatnak két fontos tulajdonsága van: Értéke Típusa 2 Adat típusa Az adatot kódoltan tároljuk
Kiegészítő részelőadás 1. Az algoritmusok hatékonyságának mérése
Kiegészítő részelőadás 1. Az algoritmusok hatékonyságának mérése Dr. Kallós Gábor 2014 2015 1 Az Ordó jelölés Azt mondjuk, hogy az f(n) függvény eleme az Ordó(g(n)) halmaznak, ha van olyan c konstans (c
Bevezetés a programozásba I 3. gyakorlat. PLanG: Programozási tételek. Programozási tételek Algoritmusok
Pázmány Péter Katolikus Egyetem Információs Technológiai Kar Bevezetés a programozásba I 3. gyakorlat PLanG: 2011.09.27. Giachetta Roberto groberto@inf.elte.hu http://people.inf.elte.hu/groberto Algoritmusok
Már megismert fogalmak áttekintése
Interfészek szenasi.sandor@nik.bmf.hu PPT 2007/2008 tavasz http://nik.bmf.hu/ppt 1 Témakörök Polimorfizmus áttekintése Interfészek Interfészek kiterjesztése Eseménykezelési módszerek 2 Már megismert fogalmak
INFORMATIKA javítókulcs 2016
INFORMATIKA javítókulcs 2016 ELMÉLETI TÉTEL: Járd körbe a tömb fogalmát (Pascal vagy C/C++): definíció, egy-, két-, több-dimenziós tömbök, kezdőértékadás definíciókor, tömb típusú paraméterek átadása alprogramoknak.
Matlab alapok. Baran Ágnes. Baran Ágnes Matlab alapok Elágazások, függvények 1 / 15
Matlab alapok Baran Ágnes Elágazások, függvények Baran Ágnes Matlab alapok Elágazások, függvények 1 / 15 Logikai kifejezések =, ==, = (két mátrixra is alkalmazhatóak, ilyenkor elemenként történik
Algoritmizálás. Horváth Gyula Szegedi Tudományegyetem Természettudományi és Informatikai Kar
Algoritmizálás Horváth Gyula Szegedi Tudományegyetem Természettudományi és Informatikai Kar horvath@inf.u-szeged.hu 0.1. Az algoritmikus tudás szintjei Ismeri (a megoldó algoritmust) Érti Le tudja pontosan
Algoritmuselmélet 2. előadás
Algoritmuselmélet 2. előadás Katona Gyula Y. Budapesti Műszaki és Gazdaságtudományi Egyetem Számítástudományi Tsz. I. B. 137/b kiskat@cs.bme.hu 2002 Február 12. ALGORITMUSELMÉLET 2. ELŐADÁS 1 Buborék-rendezés
Programozási tételek. Dr. Iványi Péter
Programozási tételek Dr. Iványi Péter 1 Programozási tételek A programozási tételek olyan általános algoritmusok, melyekkel programozás során gyakran találkozunk. Az algoritmusok általában számsorozatokkal,
Programozási segédlet
Programozási segédlet Programozási tételek Az alábbiakban leírtam néhány alap algoritmust, amit ismernie kell annak, aki programozásra adja a fejét. A lista korántsem teljes, ám ennyi elég kell legyen
Bevezetés a programozásba. 5. Előadás: Tömbök
Bevezetés a programozásba 5. Előadás: Tömbök ISMÉTLÉS Specifikáció Előfeltétel: milyen körülmények között követelünk helyes működést Utófeltétel: mit várunk a kimenettől, mi az összefüggés a kimenet és
Programozás alapjai C nyelv 7. gyakorlat. Függvények. Függvények(2)
Programozás alapjai C nyelv 7. gyakorlat Szeberényi Imre BME IIT Programozás alapjai I. (C nyelv, gyakorlat) BME-IIT Sz.I. 2005.11.05. -1- Függvények C program egymás mellé rendelt függvényekből
Függvények. Programozás alapjai C nyelv 7. gyakorlat. LNKO függvény. Függvények(2) LNKO függvény (2) LNKO függvény (3)
Programozás alapjai C nyelv 7. gyakorlat Szeberényi Imre BME IIT Függvények C program egymás mellé rendelt függvényekből áll. A függvény (alprogram) jó absztrakciós eszköz a programok
Algoritmizálás, adatmodellezés tanítása 1. előadás
Algoritmizálás, adatmodellezés 1. előadás Az algoritmus fogalma végrehajtható (van hozzá végre-hajtó) lépésenként hajtható végre a lépések maguk is algoritmusok pontosan definiált, adott végre-hajtási
I. A DIGITÁLIS ÁRAMKÖRÖK ELMÉLETI ALAPJAI
I. A DIGITÁLIS ÁRAMKÖRÖK ELMÉLETI ALAPJAI 1 A digitális áramkörökre is érvényesek a villamosságtanból ismert Ohm törvény és a Kirchhoff törvények, de az elemzés és a tervezés rendszerint nem ezekre épül.
Algoritmusokfelülnézetből. 1. ELŐADÁS Sapientia-EMTE
Algoritmusokfelülnézetből 1. ELŐADÁS Sapientia-EMTE 2015-16 Algoritmus Az algoritmus kifejezés a bagdadi arab tudós, al-hvárizmi(780-845) nevének eltorzított, rosszul latinra fordított változatából ered.
Kiterjesztések sek szemantikája
Kiterjesztések sek szemantikája Példa D Integer = {..., -1,0,1,... }; D Boolean = { true, false } D T1... T n T = D T 1... D Tn D T Az összes függvf ggvény halmaza, amelyek a D T1,..., D Tn halmazokból
Felvételi vizsga mintatételsor Informatika írásbeli vizsga
BABEȘ BOLYAI TUDOMÁNYEGYETEM MATEMATIKA ÉS INFORMATIKA KAR A. tételsor (30 pont) Felvételi vizsga mintatételsor Informatika írásbeli vizsga 1. (5p) Egy x biten tárolt egész adattípus (x szigorúan pozitív
8. gyakorlat Pointerek, dinamikus memóriakezelés
8. gyakorlat Pointerek, dinamikus memóriakezelés Házi ellenőrzés Egy számtani sorozat első két tagja A1 és A2. Számítsa ki a sorozat N- dik tagját! (f0051) Egy mértani sorozat első két tagja A1 és A2.
HORVÁTH ZSÓFIA 1. Beadandó feladat (HOZSAAI.ELTE) ápr 7. 8-as csoport
10-es Keressünk egy egész számokat tartalmazó négyzetes mátrixban olyan oszlopot, ahol a főátló alatti elemek mind nullák! Megolda si terv: Specifika cio : A = (mat: Z n m,ind: N, l: L) Ef =(mat = mat`)
Pénzügyi algoritmusok
Pénzügyi algoritmusok A C++ programozás alapjai Tömbök (3. rész) Konstansok Kivételkezelés Tömbök 3. Többdimenziós tömbök Többdimenziós tömbök int a; Többdimenziós tömbök int a[5]; Többdimenziós tömbök
Adatszerkezetek Hasító táblák. Dr. Iványi Péter
Adatszerkezetek Hasító táblák Dr. Iványi Péter 1 Hash tábla A bináris fáknál O(log n) a legjobb eset a keresésre. Ha valamilyen közvetlen címzést használunk, akkor akár O(1) is elérhető. A hash tábla a
PROGRAMOZÁSI TÉTELEK
PROGRAMOZÁSI TÉTELEK Összegzés tétele Adott egy N elemű számsorozat: A(N). Számoljuk ki az elemek összegét! S:=0 Ciklus I=1-től N-ig S:=S+A(I) Megszámlálás tétele Adott egy N elemű sorozat és egy - a sorozat
Programozás alapjai gyakorlat. 2. gyakorlat C alapok
Programozás alapjai gyakorlat 2. gyakorlat C alapok 2016-2017 Bordé Sándor 2 Forráskód, fordító, futtatható állomány Először megírjuk a programunk kódját (forráskód) Egyszerű szövegszerkesztőben vagy fejlesztőkörnyezettel
Algoritmusok és adatszerkezetek I. 1. előadás
Algoritmusok és adatszerkezetek I 1 előadás Típusok osztályozása Összetettség (strukturáltság) szempontjából: elemi (vagy skalár, vagy strukturálatlan) összetett (más szóval strukturált) Strukturálási