• Nem Talált Eredményt

Listaelemeken végiglépkedő ciklus

In document oktatási segédanyag LibreLogo (Pldal 86-91)

Listaelemeken végiglépkedő ciklus

A Listák, hivatkozás listaelemekre fejezetben megismerkedtünk a listákkal, tvala-mint néhány alkalmazásukkal. Most totvább bőtvítjük a listákkal kapcsolatos isme-reteinket.

Ha listákkal dolgozunk, akkor nagyon sokszor előfordul, hogy a listaelemeket egyesétvel kell megtvizsgálnunk. Vegyük például a kötvetkező feladatot.

Feladat: Pisti nagyon szereti a flmeket, a kedtvenceit DVD-n is megtvásárolja, amelyeket egy külön polcon tart. A DVD-kről nyiltvántartást tvezet egy listában. A lista alapján rajzoljuk meg Pisti DVD-s polcát!

filmek = [„Gyűrűk ura 1.”, „Gyűrűk ura 2.”, „Gyűrűk ura 3.”, „Hobbit”, „Gru”, „Gru 2”,

„Jurassic Park”, „Avatar”, „Hupikék törpikék”, „Hupikék törpikék 2”]

Ahhoz, hogy meg tudjuk rajzolni a DVD-ket, minden listaelemre szükségünk tvan szépen sorban. Ha tudjuk, hány listaelem tvan, akkor az ismétlés utasítás se-gítségétvel tvégiglépkedhetünk a listán. A listaelemek számát a darab utasítás se-gítségétvel kaphatjuk meg, ahogy azt a listákról szóló fejezetben megmutatuk.

filmek = [„Gyűrűk ura 1.”, „Gyűrűk ura 2.”, „Gyűrűk ura 3.”, „Hobbit”, „Gru”, „Gru 2”,

„Jurassic Park”, „Avatar”, „Hupikék törpikék”, „Hupikék törpikék 2”]

ismétlés darab filmek [ ki filmek[hányadik–1]

]

Ugye emlékszünk, hogy az ismétlésbeli hányadik tváltozó első értéke 1, majd 2 stb. miközben a flmek lista első elemére a filmek[0] kifejezéssel hitvatkozhatunk?

Ezért kell minden lépésben a filmek[hányadik–1] elemet kiírnunk.

Ugyanezt megtehetjük egy új programszerkezet segítségétvel, amely könnyeb-ben oltvashatótvá teszi a kódot:

fut film filmek-ben [ ki film

]

A fut film filmek-ben szerkezet szintén egy ciklust eredményez (hasonlóan az ismétléshez). A kifejezés után szögletes zárójelek közöti utasítások annyiszor hajtódnak tvégre, ahány eleme tvan a flmek listának, közben a flm tváltozó sorban feltveszi a flmek lista elemeinek értékét. A film tváltozónétv helyet tetszőleges tvál-tozónetvet használhatunk tvolna, de könnyíti a kód értelmezését, ha beszédes ne-tveket adunk a tváltozóinknak, ezért tvolt célszerű a film netvet tválasztanunk.

Gyűrűk ura 1. Gyűrűk ura 2. Gyűrűk ura 3. Hobbit Gru Gru 2 Jurassic Park Atvatar Hupikék törpikék Hupikék törpikék 2

listaelemeken végiglépkedő ciklus Ezt az új szerkezetet fogjuk használni a feladatunk megoldására! A DVD-knek csak az oldala látszódik, ezt egy téglalapként fogjuk megjeleníteni, amelynek a felirata lesz a DVD címe. A DVD-borítóknak tvéletlenszerű színt adunk.

balra 90

fut film filmek-ben [ töltőszín tetszőleges téglalap [100, 15]

szöveg film

tollatfel hátra 15 tollatle ]

A hányadik tváltozó a fut szerkezet esetén is él. Így például könnyen tválaszt kaphatunk arra a kérdésre, hogy hányadik helyen tvan az Atvatar című DVD?

fut film filmek-ben [ ha film == „Avatar” [ ki hányadik ]

]

Az elemek indexére tvonatkozó kérdésre ciklus nélkül is megkaphatjuk a tvá-laszt, ha a lista adatszerkezet saját index() eljárását használjuk. Előte a -ban/-ben segítségétvel meg kell győződni arról, hogy a kereset elem biztosan megtalálható az adatok közöt (totvábbá mitvel a listaelemek indexe 0-tól számozódik, nem pedig 1-től, mint a hányadik, a tvisszaadot értékhez még hozzáadtunk egyet):

ha „Avatar” filmek-ben [ ki filmek.index(„Avatar”) + 1 ]

Feladatok

57) Készíts oszlopdiagramot egy listában tárolt értékek alapján!

listaelemeken végiglépkedő ciklus

58) Rajzoljunk ritmusokat lista alapján pl. ritmus = [„ta”, „ta”, „titi”, „ta”, „titi”,

„titi”, „ta”, „ta”]

59) Készíts erdő nétven eljárást, amely egy lista alapján kirajzolja az erdőt! Pél-dául az erdő eljárás fák = [„fa”, „fenyő”, „fa", „fenyő”, „fa”, „fa”, „fenyő”, „fenyő”, „fa”,

„fenyő”] listából az alábbi rajzot készíti:

60) Készíts virágoskert nétven eljárást, amely egy lista alapján kirajzolja az er-dőt. Például a virágok = [[„virág”, „lila”], [„virág”, „narancs”], [„virág”, „piros”], [„tu-lipán”, „rózsaszín”], [„tu[„tu-lipán”, „piros”], [„tu[„tu-lipán”, „piros”], [„virág”, „piros”]] listából az alábbi rajzot készíti:

Megjegyzés: a példában szereplő lista elemei is listák. Hitvatkozhatunk ezek ele-meire ketős indexszel is, például a virágok[0][0] értéke „tvirág”, a virágok[0][1] ér-téke „lila”. Nincs szükség azonban ketős indexekre, csak egyszeresekre, ha a cik-lustváltozó nem a tvizsgált elem sorszámát, hanem magát a tvizsgált elemet (a két-elemű listát) tartalmazza a fut -ban/-ben programszerkezet segítségétvel.

61) Az építendő lakótelepen létvő házak emeleteinek számát egy lista tartalmaz-za. Készítsünk a lista alapján a lakótelepről láttványtertvet! Például, ha a házak = [1, 2, 1, 3, 2, 2] lista tartalmazza a házak emeleteinek számát, akkor a kötvetkező láttványtertvet kapjuk:

ciklus amíg (feltételes ciklus)

Ciklus amíg (feltételes ciklus)

Ezútal ismét egy ciklusfajtát fogunk megismerni. Mielőt ezt bemutatnám, tér-jünk egy kicsit tvissza Pisti DVD-s polcára. Legutóbb arra kerestük a tválaszt, hogy hányadik helyen található az Atvatar című flm. Erre a kérdésre a kötvetkező mó-don kaptunk tválaszt:

fut film filmek-ben [ ha film == „Avatar” [ ki hányadik ]

]

Ez a ciklus mindig tvégigmegy az egész listán (tvégignézi az egész polcot), mi-közben ha belegondolunk, elegendő lenne addig tvizsgálni a DVD-ket, ameddig meg nem találjuk az Atvatar címűt. Ennek főleg akkor tvan jelentősége, ha renge-teg adatot tartalmazó listátval dolgozunk, ugyanis a számítógépnek is szüksége tvan időre a feladatok megoldásához (még ha néha úgy is tűnik, hogy azonnal old-ja meg őket), tehát a programunk írásakor törekednünk kell arra, hogy minél ke-tvesebb lépésben oldja meg a feladatot, ezáltal gyorsabban fog működni.

Tehát azt szeretnénk, hogy csak addig tvizsgáljuk a flmeket, ameddig meg nem találtuk az Atvatart. Erre szolgál az úgynetvezet amíg-os tvagy feltételes ciklus (an-golul while ciklus). Ez a ciklusfajta addig ismétli a ciklusmagban létvő (LibreLogó-ban a szögletes zárójelek közöti) utasításokat, amíg egy bizonyos feltétel igaz. Te-hát addig kell lépkedni, amíg a tvizsgált elem nem egyezik meg az Atvatarral. Néz-zük meg ennek a megtvalósítását:

sorszám = 0

amíg filmek[sorszám]!= „Avatar” [ sorszám = sorszám+1

]

ki sorszám+1

Ennél a ciklusfajtánál, ha listaelemeket tvizsgálunk, akkor nyiltván kell tarta-nunk, hogy éppen hányadik listaelemnél tartunk, erre szolgál a fenti példában a sorszám netvű tváltozó. Amíg a tvizsgált sorszámú flm nem az Atvatar, addig nötvel-jük a sorszám értékét eggyel. Az ismétlődés akkor áll meg, ha a feltétel már nem teljesül, tehát a soron kötvetkező flm az Atvatar. Ekkor a sorszám a flmek listában az Atvatar sorszáma lesz. Mitvel a listaelemek számozását 0-tól kezdjük, ezért kell a kiíráskor a sorszámnál eggyel nagyobbat kiírni.

ciklus amíg (feltételes ciklus)

Feltételes ciklusokat leggyakrabban eldöntési, kitválasztási és keresési felada-tokban használunk, totvábbi példákat találsz a megfelelő programozási tételeknél, a 106. oldaltól kezdődően.

Feladatok

62) Rajzolj ki egyre kisebb négyzeteket: a program kérje be a legnagyobb négy-zet oldalhosszát, majd innentől kezdtve addig rajzoljon egyre kisebb négynégy-zeteket, amíg az aktuális négyzet oldalhossza nagyobb, mint 1 pont!

63) Készíts tetszőleges alakzatból álló oldalszegélyt úgy, hogy a teknőc akkor forduljon, ha a lap szélétől 1 cm tátvolságnál közelebb ért, és akkor hagyja abba a mintarajzolást, ha tvisszaért a kiindulópontba.

L i b r e L o g o

In document oktatási segédanyag LibreLogo (Pldal 86-91)