```
Demotilanne:
- Pisteet päivittyvät pienellä viiveellä.
- Värit: Punainen - puutteellinen. Vihreä - hyväksytty (vähintään 6p, joista 2p tähtiä)
Please
Osa-alue |
0 |
1 |
2 |
3 |
4 |
5 |
6 |
7 |
8 |
9 |
10 |
11 |
12 |
12 |
12 |
Luennot | 1&2 | 3&4 | 5&6 | 7&8 | 9&10 | 11&12 | 13&14 | 15&16 | 17&18 | 19&20 | 21&22 | 23&24 | |||
Deadlinet |
HT1 (suun- nitelma) |
Väli- kysely |
Debug- näyte |
HT2 (50%) |
Tentti- ilmo |
HT3 (100%) |
Tentti | ||||||||
Ohjaus | 1 | 2 | 3 | 4 | 5 | ||||||||||
Demo | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | Summa | d% | |
Pisteet |
Please |
Please |
Please |
Please |
Please |
Please |
Please |
Please |
Please |
Please |
Please |
Please |
Please |
Please |
|
Korjattu |
Please |
Please |
Please |
Please |
Please |
Please |
Please |
Please |
Please |
Please |
Please |
||||
Tunnit |
Please |
Please |
Please |
Please |
Please |
Please |
Please |
Please |
Please |
Please |
Please |
Please |
Please |
Please |
Please |
Ohjelmointi 1, syksy 2024 / Demo 4
Tehtävät perustuvat luentoihin: 07 ja 08.
OPPIMISTAVOITTEET
Täytä sitä mukaa, kun koet oppineesi uusia asioita. Työkirja-sivulla näet yhteenvedon kaikkien demojen osalta.
Muista, että kunkin demokerran minimipistemäärä 2 on tehtävä käyttäen tähdellä (*
) merkittyjä tehtäviä. Esim. pelkkä Ville ja Tauno ei riitä minimimäärään. Jos tehtävät eivät lähde luonnistumaan, kannattaa käydä pääteohjauksissa hakemassa apua.
Muista että B
-tehtävät ovat Bonus tehtäviä, joiden tekemiseksi joutuu yleensä etsimään materiaalia kurssin sen hetken materiaalin ulkopuolelta (esim. lukemalla monistetta eteenpäin). Jos niitä ei osaa tehdä, se ei ole vielä vakavaa.
G
-tehtävät ovat Guru-tehtäviä, jossa pitää jo osata selkeästi enemmän kuin kurssin taso tällä hetkellä.
Tauno 1a
Tauno 1b
Ville 1
Tee Ville-tehtävät 3.3, 3.5, 3.6. 4.1-4.4. Sanoin luennolla että Villen merkkijonot toimivat kuten Javassa, mutta tuo taitaa nyt olla korjattu Villessä, eli Substring
-metodin jälkimmäinen indeksi on merkkien määrä.
Tehtävä 3.3 on tehty jo aiemmin, tässä pitäisi varmaan olla 3.4?
VL: mielestäni demo3:ssa oli: 3.1, 3.2, 3.4
—Muista Villen käyttöohje.
Funktioista F1
Mikäli olit luennolla 5, voit hypätä kohdan 1 yli ja jatkaa suoraan tämän tehtävän kohdasta 2.
Mikäli et ollut luennolla 05 tai et saanut luennolla tehtyä sitä tehtävää, jossa opiskelijat "leikkivät" aliohjelmia ja "paperilaput" parametrejä, tee se nyt yksin tai yhden/kahden kaverin kanssa.
Seuraavaksi lue huolella monisteen luku 9. Aliohjelman paluuarvo.
Suorita kohdan 9.2 Funktion kutsuminen lopussa oleva animaatio huolella miettien, mitä tapahtuu ja miten asiat samaistuvat luentojen "paperilappujen leikkiesimerkkiin".
Aja kohdan 9.3 Funktion kirjoittaminen toisella tavalla toisen esimerkin testit. Vaihda
2.0
tilalle2
. Aja testit ja katso, mitä tapahtuu. Vaihda jakolaskun tilalle kertominen luvulla0.5
ja aja testit uudelleen.
Katso alla olevat molemmat animaatiot ajatuksen kanssa.
Kirjoita alle:
- mitä opit animaation ja luentojen "paperilappujen" antamisen yhteydestä?
- mitä hyötyä oli testeistä?
- miksi sanotaan, että merkijono on muuttumaton (immutable) vaikka merkkijonoanimaation esimerkissä muuttuja
jono
muuttui? - jos vastauksesi on että et oppinut uutta, niin milloin opit em asiat
TDD 1
Lue ensin: 11. Comtest.
Jos teet itse omia testejä vähintään kahteen funktioon (esim ComTest) Visual Studiossa tai vastaavassa, saat merkitä yhden lisäpisteen. Testit eivät saa olla täsmälleen samoja kuin mitkä saa kopioimalla tehtävien TIM-versiosta. Vastauksena kerrot minkä tehtävän ja minkä funktion/funktioiden toiminnan testasit. Voit antaa samalla palautetta ja kehitysehdotuksia Comtestin käytöstä. Huom! Ohjelmia joissa on pelkkä pääohjelma on vielä tämän kurssin tiedoilla aika haastavaa testata, samoin esim. pelijuttuja. Siksi testaamista kannattaa ehkä tehdä tässä demoissa vain sellaisille funktioille, jotka selkeästi palauttavat jotakin. Tässä demossa sellaisia on tehtävissä 2, 5 ja 6.
Jos ComTest ei toimi koneellasi, voit Copy/Pasteta ohjelmia alla olevaan laatikkoon ja testata siinä.
Tehtävä 1. Pong tai työaikatutoriaali
Valitse ja tee jompikumpi seuraavista:
(Peli) Tee Pong-tutoriaalista vaiheet 4-7. Näitä ei voi tehdä TIMissä, vaan on käytettävä esimerkiksi Visual Studiota. (Tee myös vaiheet 1-3 ellet niitä vielä ohjaustehtävinä tehnyt)
(Ei-peli) Tutustu työaikaraportti tutoriaaliin Kuten Pongissakin, kirjoita alle muutaman kappaleen mittainen oppimispäiväkirja vastaavilla kriteereillä.
Kirjoita valitsemastasi tehtävästä parin kappaleen mittainen oppimispäiväkirja (väh. 5 riviä). Kerro mitä opit, mitkä asiat olivat uusia, helppoja ja vaikeita. Oliko tästä tehtävästä sinulle hyötyä? Voit antaa myös palautetta tehtävien sisällöistä. (Pong-tutoriaalin kooditiedostoja EI tarvitse palauttaa)
Tehtävä 2*. Merkkijonojen vertailu
Lue ensin: 12. Merkkijonot ja 13. Ehtolauseet.
Tee funktio, joka palauttaa kahdesta merkkijonosta lyhyemmän. Jos jonot ovat yhtä pitkät, palautetaan vertailtavista jonoista aina ensimmäinen.
- Käytä apunasi luentomonisteen Merkkijonot-lukua.
Tätä tehtävää tehdessä älä yhtään mystifioi asioita. Kyseessä on samanlainen tehtävä kuin edellisviikonkin demoissa! Ainoana erona on eri tyyppiset muuttujat ja hieman erilainen toteutus. Mitään sen ihmeellisempää tässä ei tosiaan ole.
Muista jakaa funktion rakentaminen osiin:
- Funktion esittelyrivi ja runko
- Dokumentaatio
- Tynkä
- Testaus
- Toteutus
Voit edelleen jakaa toteutuksen vaiheisiin:
- Saan kaksi merkkijonoa (sanaa), joista lyhempi pitää palauttaa!
- Mistä olen kiinnostunut? En jonojen sisällöstä vaan sana1:n XXX ja sana2:n XXX.
- Miten saan selville XXX? Mikä on XXX tyyppi?
- Vertaan jonojen XXX ja päättelen sen perusteella mitä palautetaan.
- Mitä tyyppiä palautettavan tuloksen pitää olla?
Jos näissä on vielä vaikeuksia, voit aloittaa harjoitustehtävällä.
Mikähän tästä puutuu, kun sa 0,9 pistettä? Kommentointi ja testaus on kuitenkin tehtävän annossa, joten niiden puuttumisesta ei pitäisi rokottaa. Vai enkö näe jotain? Sama seuraavassa tehtävässä.
VL: Syntyneen dokumentin lukeminen. Paina Document
ja tutki miksi siellä mitäkin lukee suhteessa mitä koodiin on kirjoitettu (Näytä koko koodi
). Lisäsin vielä tuohon tehtävän alle. Avoimen demoista nähtävästi tämä huomautus on puuttunut...
Huomaa! TIMissä konsolilta lukeminen ei toimi samalla tavalla kuin oikeassa ohjelmassa. TIMissä käyttäjän syöte pitää antaa sille varattuun tilaan ENNEN ohjelman ajamista.
Huomaa! Tästä lähtien täysien pisteiden saamiseksi pitää jokaisessa tehtävässä lukea millainen dokumentaatio ohjelmasta syntyy sen ansiosta mitä kommentteja ohjelmaan on kirjoitettu. Eli katso Näytä koko koodi
ja paina Document
ja vertaa mitä dokumentaatioon tulee.
Tehtävä 3 Ääkköset aakkosiksi
Lue ensin: 12. Merkkijonot ja 13. Ehtolauseet.
(vinkki: katso String-luokan dokumenttia ja etsi metodi, jolla voit vaihtaa kirjaimia. Tiedon lukemista varten katso edellisen tehtävän pääohjelmaa (tässä tehtävässä ei välttämättä tarvitsisi itse kirjoittaa yhtään aliohjelmaa, tosin tulevia demoja ajatellen apufunktiosta ei ole haittaakaan)
Muista jakaa funktion rakentaminen osiin:
- Funktion esittelyrivi ja runko
- Dokumentaatio
- Tynkä
- Testaus
- Toteutus
Voit edelleen jakaa toteutuksen vaiheisiin:
- Saan kaksi merkkijonoa (sanaa), joista lyhempi pitää palauttaa!
- Mistä olen kiinnostunut? En jonojen sisällöstä vaan sana1:n XXX ja sana2:n XXX.
- Miten saan selville XXX? Mikä on XXX tyyppi?
- Vertaan jonojen XXX ja päättelen sen perusteella mitä palautetaan.
- Mitä tyyppiä palautettavan tuloksen pitää olla?
Jos näissä on vielä vaikeuksia, voit aloittaa harjoitustehtävällä.
Tee Console-ohjelma, joka toimisi seuraavasti:
Muutan virkkeesi ääkköset kansainvälisesti käypään muotoon!
Anna teksti >Äänekoskella haisee myös öisin.
Muutettu virke: Aeaenekoskella haisee myoes oeisin.
Eli muuttaa sekä pienet että isot ääkköset yleisesti toimiviksi aakkosiksi.
Å -> Aa & å -> aa
Ä -> Ae & ä -> ae
Ö -> Oe & ö -> oe
Tehtävä 4. Char-luokka
Lue ensin: 12.8 Char-luokka ja 6. Aliohjelmat.
a) Kirjain isoksi
Katso, mikä kutsu sinun on kirjoitettava XXX
:n paikalle, jotta seuraava ohjelma toimisi:
b) Iso vai pieni
Tee funktio, joka palauttaa tiedon merkkijonon viimeisen merkin koosta (joko "pieni"
tai "iso"
).
Lisäksi:
- Jos viimeistä merkkiä ei ole eli jono on tyhjä, palautetaan aina
"iso"
. - Jos viimeinen merkki on jokin muu kuin kirjain (esim.
'.'
), palautetaan aina"pieni"
.
Vinkki! Jaa ongelma aluksi jälleen selkeästi pienempiin osiin:
- Voinko edes ottaa viimeisen merkin? Missä tilanteessa en? Mitä silloin palautetaan?
- Miten saan jonon viimeisen kirjaimen?
- Miten tutkin, onko viimeinen kirjain iso?
- Miten tuon perusteella palautan tekstin
"iso"
tai"pieni"
?
Mieti myös, mikä on merkkijonon viimeisen merkin indeksi?
c) Ensimmäinen isoksi
Tee funktio Isoksi
, joka ensin poistaa jonosta kaikki alussa ja lopussa olevat välilyönnit (ks. Trim()) ja sitten muuttaa merkkijonon ensimmäisen merkin isoksi ja palauttaa muutetun merkkijonon. Katso tarvittaessa erikoistapaukset funktion testeistä (Näytä koko koodi).
Vinkki! Kannattaa hyödyntää a-kohdan vastausta hyödyksi ohjelman kirjoittamisessa.
Mitä tarkoittaa demossa herja: Run error: File size limit exceeded
VL: sulla on ikuinen rekursio joka täyttää kok okoneen muistin.
—Tehtävä 5*. Aikaisin ja viimeisin I
Lue ensin: 13. Ehtolauseet, 27. ASCII-koodi ja Lukuja.cs.
a) Kolmen aakkosen aikaisin ja viimeisin
Tee ohjelma, joka kysyy kolme kirjainta ja tulostaa niistä aakkosissa aikaisimman ja viimeisimmän (eli esim. aikaisin palauttaisi sen syötetyn kirjaimen, joka tulee aakkosissa ekana vastaan). Sovitaan, että käytetään VAIN PIENIÄ KIRJAIMIA. Tee avuksi funktioaliohjelmat Aikaisin
ja Viimeisin
(joille kummallekin viedään kolme parametriä).
Vinkki! Kirjaimia (jotka ovat merkkejä eli tyypiltään char
) voidaan vertailla samoilla operaattoreilla keskenään kuin lukuarvojakin (esim. <
ja =
).
b) Muiden merkkien suhde kirjaimiin
b-kohdassa tekemälläsi aakkosia vertailevalla ohjelmalla ei oikeasti vertailla ainoastaan kirjaimia. Sillä voidaan vertailla kaikkia merkkejä, kuten vaikkapa '!'
, ' '
ja '%'
. Tämä johtuu siitä, että kaikille kansainvälisille merkeille on määritetty jokin vertailtailukelpoinen kokonaislukuarvo, jota yksinkertaisten kansainvälisten merkkien tapauksessa kutsutaan ASCII-koodiksi (American Standard Code for Information Interchange).
Vertaile merkkejä '!', '[', 'a', '#', 'B', '3', 'b', '\', 'A', '?'
ja selvitä niiden ASCII-koodiin perustuva järjestys käyttämällä 5a kohdassa tekemääsi ohjelmaa. Anna vastauksesi pienimmästä suurimpaan, kaikki yhteen putkeen ja yhdellä rivillä.
Vinkki! Pelkän ASCII-koodin on korvannut UTF-8 koodaus, jota käytetään nykyään kansainvälisesti ympäri maailmaa. Video ASCII-koodista ja UTF-8:sta.
Tehtävä 6. Merkkijonon pätkiminen I
Lue ensin: 12. Merkkijonot, Jonoja.cs, Merkkijonoja.cs ja Aliohjelminen kutsuminen.
Tee tarvittavat aliohjelmat, jotta seuraava pääohjelma toimisi.
public static void Main()
{
Console.Write("Anna sähköpostiosoitteesi: ");
string kokonimi = Console.ReadLine();
string kayttajanimi = AnnaKayttajanimi(kokonimi);
string verkkotunnus = AnnaVerkkotunnus(kokonimi);
Console.WriteLine($"Käyttäjätunnuksesi on siis \"{kayttajanimi}\"" +
$"ja verkkotunnuksesi \"{verkkotunnus}\".");
}
Huom! Käyttäjänimellä tarkoitetaan sähköpostiosoitteen '@'
-merkkiä edeltävää osaa (juolenak@jyu.fi), kun taas verkkotunnuksella tarkoitetaan sen jälkeistä osaa (juolenak@jyu.fi).
Vinkki! Ohjelma voidaan toteuttaa valmiiden ohjelmien IndexOf
ja Substring
TAI Split
avulla. Split
vaatii kuitenkin taulukon, jota ei vielä ole käsitelty. Muista aina painaa Näytä koko koodi
nähdäksesi pääohjelman.
L1. Liukuhihna
Dokumentissa Liukuhihna on hauska robotti. Vastaa siellä oleviin kysymyksiin. Maksimissaan voit tuolta kerätä 2.5 p. Kirjoita alla olevaan tehtävään miltä liukuhihnatehtävä tuntui ja laita itse tehtävän pisteisiin liukuhihnan tuloksesi. Saat tehdä tähän demoon sen tehtävästä osan jota et jo tehnyt demo2:ssa tai demo3:ssa, kunhan kumpaankin merkkaamasi (demo2 + demo3 + demo4) summa on sama kuin Liukuhihnatehtävän pistemäärä.
Huom!. Pisterajatarkistus ei vättämättä toimi, joten et saa huijata laittamalla liikaa pisteitä!
B1. Lumiukko V
Lue ensin: Optional arguments.
Ota demojen 3 mallivastaus tehtävään Lumiukko III, jossa kuormitettiin aliohjelmaa PiirraYmpyra
tekemällä sille kaksi toteutusta, jotta ohjelmaa voitiin kutstua eri tavoilla.
Vaihda ohjelman kuormitus nyt C#:n valinnaisiin parametreihin, joilla saadaan sama lopputulos aikaiseksi. Ainoaksi eroksi (ja eduksi) jää se, että tuo kuormituksen aikaansaama joustavuus saadaan nyt aiakiseksi vain yhden aliohjelman avulla kahden sijaan.
G1. Pyrstötähdet II
Ota demojen 2 mallivastaus tehtävään Pyrstötähdet I ja aja se ensin sellaisenaan. Lisää ohjelmaan sitten pallo, jota voit itse ohjailla, ja jonka törmäys tähtiin aiheuttaa tähtien tuhoutumisen räjähdysefektissä. Poista vielä painovoiman luontilauseke, jotta tähdet pysyvät paikoillaan (tai vaihtoehtoisesti voit tehdä tähdistä staattisia objekteja).
Vinkki! Ohjailtava pallo tehtiin demojen 3 tehtävässä B1. Pallon Pukkailu. Törmäysten käsittelyyn tarvitaan Jypelin valmista ohjelmaa AddCollisionHandler
.
Huom! Kun olet tallentanut vastauksesi, arvioi oma suoriutumisesi tehtävästä asteikolla 0-2p. valitsemalla automaatin antaman pistemäärän vierestä Set custom points.
These are the current permissions for this document; please modify if needed. You can always modify these permissions from the manage page.