SlideShare a Scribd company logo
Racket
5. JAKSO
Sisällysluettelo
6A. LISTA
1. Lista: list, cons, first, rest, append, length, empty?
2. Lista: member?, remove, remove-all, list-ref
3. range
6B. LISTA JA REKURSIO
4. Listan ”syöminen” rekursiivisesti
5. Listan luominen rekursiivisesti
2
Lista
list, cons, first, rest
Lista on tietorakenne, johon voi tallentaa mitä tahansa tietoa. Tyhjään listaan
viitataan Racket-kielessä sanalla empty tai symbolilla ’().
Listan luominen:
(list 1 2 3 4 5 6)
Uuden alkion lisääminen valmiiseen listaan (lisätään aina alkuun):
(cons 7 (list 1 2 3 4 5 6)) -> (list 7 1 2 3 4 5 6)
Listan ensimmäisen alkion palauttaminen (myös second, third):
(first (list 7 1 2 3 4 5 6)) -> 7
Listan loppuosan palauttaminen (esimmäinen alkio poistetaan).
(rest (list 7 1 2 3 4 5 6)) -> (list 1 2 3 4 5 6)
3
Lista
append, length, empty?
Listojen yhdistäminen
(append (list 1 2 3)(list 4 5 6))-> (list 1 2 3 4 5 6)
Listan pituuden kysyminen
(length (list 1 2 3 4)) -> 4
Tyhjän listan tunnistaminen
(empty? ’()) -> #true
(empty? (list 1 2)) -> #false
Listassa voi olla mitä tahansa (merkkijonoja, kuvia, listoja, totuusarvoja...):
(list 3 ”Tiina” (list 1 2 3) #t)
4
Lista
member?, remove, remove-all, list-ref
Voit tutkia onko alkio listan jäsen
(member? 3 (list 4 5 6))-> #false
Voit poistaa alkion listasta
(remove 4 (list 1 2 3 4)) -> (list 1 2 3)
Voit poistaa kaikki tietyt alkiot
(remove-all 2 (list 1 2 3 2 4) -> (list 1 3 4)
Ottaa listasta tietyssä kohtaa sijaitsevan alkion (ensimmäinen alkio 0)
(list-ref (list 10 20 30) 1) -> 20
5
Listan ”syöminen” rekursiivisesti
Silmukkarakennetta voidaan käyttään esim. lista- tai puutyyppisen tietorakenteen
läpi käymiseen. Silloin ei tarvita laskuria, koska silmukan toiminta voidaan lopettaa
kun tietorakenne on käyty loppuu (esim. saavutettu listan pää).
Esim. Luetellaan ruokalista
(require teachpacks/display-read)
(define (syö-listaa lista)
(if (empty? lista)
(display-info-timer "Lista loppui” 50)
(begin (display-info-timer (first lista) 50)
(syö-listaa (rest lista)))))
(syö-listaa (list "cokis" "ranskalaiset" "jäätelö"))
6
Listan luominen rekursiivisesti
(listaan kerätään kuvia)
Lista voi olla myös akkumulaattorin paikalla, eli voit kerätä tuloksia listaan.
(require 2htdp/image)
(define (tähtiä i lista)
(if (<= i 0)
lista
(tähtiä (sub1 i)(cons (star (* i 10) "solid" "aqua") lista))))
(tähtiä 8 empty)
7
uusi tähti
lisää uuden alkion listaan
Kysytään käyttäjältä lukupareja
(kerätään listaksi)
(define (kysy-mitat n lista)
(let [(x (display-read-number "Anna x"))
(y (display-read-number "Anna y"))]
(cond [(not (or (number? x) (number? y)))
(kysy-mitat n lista)]
[(<= n 1)
(cons (list x y) lista)]
[else
(kysy-mitat (sub1 n) (cons (list x y) lista))])))
(kysy-mitat 5 empty)
8
akkumulaattori
lopetusehto
Listoja hyödyntävät
interaktiiviset ohjelmat
Tunnistuspeli ja valintapeli
Kysymykset ja vastaukset kerätään listaksi, jota käydään läpi rekursiivisen silmukan avulla.
(define KYSYMYKSET (list (list OMENA-KYSYMYS "omena")
(list PAPRIKA-KYSYMYS "paprika")))
;; pelaa : Lista Luku -> Luku
(define (pelaa peli pisteet)
(if (empty? peli)
(display-value "Sait pisteitä:" pisteet)
(if (oikein? (first peli) (display-read (first (first peli))))
(begin (display-info "Oikein")
(pelaa (rest peli) (add1 pisteet)))
(begin (display-info "Väärin")
(pelaa (rest peli) pisteet)))))
;; käynnistää pelin (alussa pisteitä 0)
(pelaa KYSYMYKSET 0)
KOODIAAPINEN MOOC - SYKSY 2015
Vinkkejä palautettavaan
jaksotehtävään
Voit tehdä oman versiosi tunnistus- tai valintapelistä. Voit käyttää
malliratkaisuja pohjana omalle pelillesi. Voit myös halutessasi soveltaa
listatietojasi vasta jaksolla 6. Turtle grafiikan parissa (jaksot 5. ja 6.
käsittelevät molemmat listoja).
Jotta muutkin kurssilaiset pääsevät pelaamaan peliäsi, jaa se
WeSchemen kautta!
KOODIAAPINEN MOOC - SYKSY 2015

More Related Content

PPTX
Racket jatko 6. Listat
PPTX
Racket MOOC - jakso 6
PPTX
Racket Turtle
PPTX
Racket MOOC (kevät 2016) - jakso 4
PPTX
Racket MOOC viikko 5
PPTX
Racket MOOC - jakso 1
PPTX
Racket MOOC - jakso 3
PPTX
Racket jatko 5. Rekursio
Racket jatko 6. Listat
Racket MOOC - jakso 6
Racket Turtle
Racket MOOC (kevät 2016) - jakso 4
Racket MOOC viikko 5
Racket MOOC - jakso 1
Racket MOOC - jakso 3
Racket jatko 5. Rekursio

What's hot (7)

PPTX
Racket mooc - viikko 2
PPTX
Racket MOOC - jakso 2
PPTX
Racket perusteet 3. Funktio
PPTX
Racket perusteet - Sovellukset A
PPTX
Racket MOOC - viikko 3
PDF
Ohjelmointi yläkoulussa: Jatkokurssi
PPTX
Racket MOOC - 1. viikko
Racket mooc - viikko 2
Racket MOOC - jakso 2
Racket perusteet 3. Funktio
Racket perusteet - Sovellukset A
Racket MOOC - viikko 3
Ohjelmointi yläkoulussa: Jatkokurssi
Racket MOOC - 1. viikko
Ad

More from Tiina Partanen (16)

PDF
Computational Thinking as an Emergent Learning Trajectory of Mathematics
PPTX
Racket mooc 2017 - yleistä
PPTX
Racket mooc 2017 - aikataulu
PPTX
Racket materiaali (Koodausta kouluun - projekti)
PPTX
Ohjelmoinnin historiaa
PPTX
Racket MOOC 2016 aikataulu (SYKSY)
PPTX
Koodiaapinen MOOC - keynote
PPTX
Kurkistus koodaukseen
PPTX
Racket MOOC jakso 7
PPTX
Racket MOOC 2016 - yleistä (SYKSY)
PPTX
Legorobottialkeet
PPTX
Lapset koodaa?
PPTX
Koodauksen ensiaskeleet
PPTX
Racket MOOC - viikko 6
PPTX
Racket jatko 7. oppitunti
PPTX
Koodiaapinen MOOC - Racket
Computational Thinking as an Emergent Learning Trajectory of Mathematics
Racket mooc 2017 - yleistä
Racket mooc 2017 - aikataulu
Racket materiaali (Koodausta kouluun - projekti)
Ohjelmoinnin historiaa
Racket MOOC 2016 aikataulu (SYKSY)
Koodiaapinen MOOC - keynote
Kurkistus koodaukseen
Racket MOOC jakso 7
Racket MOOC 2016 - yleistä (SYKSY)
Legorobottialkeet
Lapset koodaa?
Koodauksen ensiaskeleet
Racket MOOC - viikko 6
Racket jatko 7. oppitunti
Koodiaapinen MOOC - Racket
Ad

Racket MOOC - jakso 5

  • 2. Sisällysluettelo 6A. LISTA 1. Lista: list, cons, first, rest, append, length, empty? 2. Lista: member?, remove, remove-all, list-ref 3. range 6B. LISTA JA REKURSIO 4. Listan ”syöminen” rekursiivisesti 5. Listan luominen rekursiivisesti 2
  • 3. Lista list, cons, first, rest Lista on tietorakenne, johon voi tallentaa mitä tahansa tietoa. Tyhjään listaan viitataan Racket-kielessä sanalla empty tai symbolilla ’(). Listan luominen: (list 1 2 3 4 5 6) Uuden alkion lisääminen valmiiseen listaan (lisätään aina alkuun): (cons 7 (list 1 2 3 4 5 6)) -> (list 7 1 2 3 4 5 6) Listan ensimmäisen alkion palauttaminen (myös second, third): (first (list 7 1 2 3 4 5 6)) -> 7 Listan loppuosan palauttaminen (esimmäinen alkio poistetaan). (rest (list 7 1 2 3 4 5 6)) -> (list 1 2 3 4 5 6) 3
  • 4. Lista append, length, empty? Listojen yhdistäminen (append (list 1 2 3)(list 4 5 6))-> (list 1 2 3 4 5 6) Listan pituuden kysyminen (length (list 1 2 3 4)) -> 4 Tyhjän listan tunnistaminen (empty? ’()) -> #true (empty? (list 1 2)) -> #false Listassa voi olla mitä tahansa (merkkijonoja, kuvia, listoja, totuusarvoja...): (list 3 ”Tiina” (list 1 2 3) #t) 4
  • 5. Lista member?, remove, remove-all, list-ref Voit tutkia onko alkio listan jäsen (member? 3 (list 4 5 6))-> #false Voit poistaa alkion listasta (remove 4 (list 1 2 3 4)) -> (list 1 2 3) Voit poistaa kaikki tietyt alkiot (remove-all 2 (list 1 2 3 2 4) -> (list 1 3 4) Ottaa listasta tietyssä kohtaa sijaitsevan alkion (ensimmäinen alkio 0) (list-ref (list 10 20 30) 1) -> 20 5
  • 6. Listan ”syöminen” rekursiivisesti Silmukkarakennetta voidaan käyttään esim. lista- tai puutyyppisen tietorakenteen läpi käymiseen. Silloin ei tarvita laskuria, koska silmukan toiminta voidaan lopettaa kun tietorakenne on käyty loppuu (esim. saavutettu listan pää). Esim. Luetellaan ruokalista (require teachpacks/display-read) (define (syö-listaa lista) (if (empty? lista) (display-info-timer "Lista loppui” 50) (begin (display-info-timer (first lista) 50) (syö-listaa (rest lista))))) (syö-listaa (list "cokis" "ranskalaiset" "jäätelö")) 6
  • 7. Listan luominen rekursiivisesti (listaan kerätään kuvia) Lista voi olla myös akkumulaattorin paikalla, eli voit kerätä tuloksia listaan. (require 2htdp/image) (define (tähtiä i lista) (if (<= i 0) lista (tähtiä (sub1 i)(cons (star (* i 10) "solid" "aqua") lista)))) (tähtiä 8 empty) 7 uusi tähti lisää uuden alkion listaan
  • 8. Kysytään käyttäjältä lukupareja (kerätään listaksi) (define (kysy-mitat n lista) (let [(x (display-read-number "Anna x")) (y (display-read-number "Anna y"))] (cond [(not (or (number? x) (number? y))) (kysy-mitat n lista)] [(<= n 1) (cons (list x y) lista)] [else (kysy-mitat (sub1 n) (cons (list x y) lista))]))) (kysy-mitat 5 empty) 8 akkumulaattori lopetusehto
  • 9. Listoja hyödyntävät interaktiiviset ohjelmat Tunnistuspeli ja valintapeli Kysymykset ja vastaukset kerätään listaksi, jota käydään läpi rekursiivisen silmukan avulla. (define KYSYMYKSET (list (list OMENA-KYSYMYS "omena") (list PAPRIKA-KYSYMYS "paprika"))) ;; pelaa : Lista Luku -> Luku (define (pelaa peli pisteet) (if (empty? peli) (display-value "Sait pisteitä:" pisteet) (if (oikein? (first peli) (display-read (first (first peli)))) (begin (display-info "Oikein") (pelaa (rest peli) (add1 pisteet))) (begin (display-info "Väärin") (pelaa (rest peli) pisteet))))) ;; käynnistää pelin (alussa pisteitä 0) (pelaa KYSYMYKSET 0) KOODIAAPINEN MOOC - SYKSY 2015
  • 10. Vinkkejä palautettavaan jaksotehtävään Voit tehdä oman versiosi tunnistus- tai valintapelistä. Voit käyttää malliratkaisuja pohjana omalle pelillesi. Voit myös halutessasi soveltaa listatietojasi vasta jaksolla 6. Turtle grafiikan parissa (jaksot 5. ja 6. käsittelevät molemmat listoja). Jotta muutkin kurssilaiset pääsevät pelaamaan peliäsi, jaa se WeSchemen kautta! KOODIAAPINEN MOOC - SYKSY 2015