Demo 4

Huomautus: Lopulliset demotehtävät julkaistaan aina tasan viikkoa ennen deadlinea. Demotehtäviin saattaa ennen sitä tulla muutoksia tai korjauksia. Tehtäviä voi tulla lisää tai tehtäviä voi poistua. Tehdessäsi tehtäviä ennen virallista julkaisua, ota tekemästäsi koodista aina varmuuskopio omalle tietokoneellesi.

Palauta ma 10.2. klo 11:59 mennessä.

Osaamistavoitteet

# Oppimistavoitteet

Ajankäyttösi tällä viikolla (0.5 p.)

Työtuntien kirjaamisesta saa 0.5 demopistettä. Aseta pisteesi Set Custom Points -toiminnolla.

Demokerran päätteeksi kirjoita arvio tällä viikolla käyttämästäsi työmäärästä. Laske työmäärään mukaan kaikki tällä viikolla (kalenteriviikko, ma klo 00:00 -- su klo 23:59) käyttämäsi aika: lähiopetukseen osallistuminen, oppimateriaalin lukeminen, demotehtävien tekeminen, luentovideon katsominen, demojen purkutilaisuuteen osallistuminen (maanantaina) ja niin edelleen. Voit päivittää lukua viikon edetessä, se voi helpottaa arvion tekemistä. Huom! Siis tähän ei laiteta kurssin alusta kaikkia tunteja yhteensä, vaan vain tämän viikon tunnit.

# d4tunnit

Huomautus custom points -pisteistä

Tehtävä 1*

Tee Pong-tutoriaalin vaiheet vaiheet 1-7. Kirjoita noin 100-200 sanan mittainen oppimispäiväkirja, jossa kerrot, mitä opit, mikä oli helppoa ja mikä vaikeaa, sekä mikä oli uutta. Kirjoita myös, oliko tästä tehtävästä sinulle hyötyä. Voit antaa myös palautetta tutoriaalin sisällöstä, ja miten sitä voisi kehittää.

Älä jää liikaa suremaan hieman omituista fysiikan käytöstä joissakin pompuissa. :-)

# demo4teht1

Tehtävä 2

Lue ensin: 7.7 Operaattorit

Alla on C#-kielisiä lausekkeita ja lauseita. Vastaa kuhunkin kohtaan.

Huomaa! Kuhunkin kohtaan on vain yksi vastausyritys.

# demo4teht2_1
# demo4teht2_2
# demo4teht2_3
# demo4teht2_4

Seuraavissa kohdissa on useita toisistaan erillisiä lauseita. Eri kohdissa olevia lauseita ei suoriteta peräkkäin.

# demo4teht2_5
# demo4teht2_6
# demo4teht2_7
# demo4teht2_8

Tekstipohjaiset tehtävät

Seuraavat tehtävät ovat tekstipohjaisia. Käytä ConsoleMain-projektimallia.

Tehtävä 3*

Lue ensin: 12. Merkkijonot, 13. Ehtolauseet.

Tehtävä: Alla on valmiiksi annettu pääohjelma. Ota siitä kopio, vie Rideriin ja täydennä sen ympärille luokka nimeltä Merkkijonot.

public static void Main(string[] args) 
{
  Console.Write("Anna 1. jono >");
  string jono1 = Console.ReadLine();
  Console.Write("Anna 2. jono >");
  string jono2 = Console.ReadLine();
  string pidempi = PidempiMerkkijono(jono1, jono2);
  Console.WriteLine("\"" + pidempi + "\" on pidempi merkkijono");
}

Toteuta siihen PidempiMerkkijono-funktio, joka ottaa vastaan kaksi merkkijonoa, ja palauttaa näistä kahdesta pidemmän merkkijonon. Jonojen ollessa yhtä pitkiä palautetaan ensimmäisenä parametrina annettu jono. Funktiossa PidempiJono EI saa tulostaa mitään.

Ohjeita ja vinkkejä tehtävän tekemiseen

Kun olet tehnyt tehtävän, kopioi funktio esittelyriveineen vastauslaatikkoon.

Arviointi: Koodin ajamisesta 0.4 p., testien läpäisemisestä 0.5 p. ja dokumentaation lukemisesta 0.1 p. Dokumentaation lukemisella tarkoitetaan ajamisen seurauksena syntyneen Document-linkin klikkaamista ja ohjelmadokumentaation tosiasiallista lukemista.

Huomioitavaa:

  • Alla olevaan vastauslaatikkoon laitetaan vain pelkkä valmis funktio, ei class eikä Main-koodia.
  • Jos tehtävää Riderissa/Visual Studiossa tehdessä tulee System.NullReferenceException-virhe, tarkasta, että olet valinnut projektin tyypiksi ConsoleMain.
  • TIMissä käyttäjän syöte pitää antaa sille varattuun tilaan ENNEN ohjelman ajamista. TIMissä konsolilta lukeminen ei toimi samalla tavalla kuin Riderissa.
# demo4teht3

Tehtävä 4

Lue ensin: 12. Merkkijonot.

Tehtävä: Alla on puolittain tehty ohjelma, johon sinun tulee tehdä valmiiksi MuutaKirjaimet-niminen funktio. Funktion tehtävänä on muuttaa r-kirjaimet (pienet ja isot) l-kirjaimiksi. Kun funktio on valmis, ohjelman tulisi toimia seuraavasti

Toistan mitä sanot, mutta en osaa sanoa l:ää!
Anna teksti  >ralliauto ajaa superkovaa.
Sanoit siis : lalliauto ajaa supelkovaa.

Vinkki: katso String-luokan dokumentaatiota ja etsi metodi, jolla voit vaihtaa kaikki kirjaimen esiintymät toiseksi kirjaimeksi. Katso edellisen tehtävän pääohjelmasta miten syötettä luetaan käyttäjän näppäimistöltä. Tässä tehtävässä ei välttämättä tarvitse itse kirjoittaa yhtään aliohjelmaa, tosin tulevia demoja ajatellen apufunktiosta ei ole haittaakaan.

Arviointi: Toimivasta ohjelmasta saa 0.4 pistettä, testien läpäisemisestä 0.5 pistettä ja dokumentaatiosta loput 0.1 pistettä.

Huomioitavaa:

  • Klikkaa Näytä koko koodi niin näet valmiiksi tehdyn ohjelman osan.
  • Alla olevaan vastauslaatikkoon laitetaan vain pelkkä valmis funktio, ei class eikä Main-koodia.
  • 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.
# demo4teht4

Tehtävä 5

Lue ensin: 13. Ehtolauseet.

Tehtävä: Tee funktiot Suurin (0.5 p.) ja Pienin (0.5 p). Suurin-funktio ottaa parametreina kolme kokonaislukua ja palauttaa luvuista suurimman. Vastaavasti Pienin-funktio palauttaa pienimmän luvun.

Vinkki: Suurin-funktiota on helpoin lähteä laajentamaan ajatuksesta

public static int Suurin(int a, int b) 
{
  int suurin = a;
  if (b > suurin) suurin = b;
  return suurin;
}

Vastaava ajatus toimi Pienin-funktiolle vähäisin muutoksin.

Arviointi: Tehtävissä on automaattinen arviointi (0.5 p. + 0.5 p.).

Huom: Alla oleviin vastauslaatikoihin laitetaan laitetaan vain valmiit funktiot (pakollinen), niihin kuuluvat dokumentaatiot (pakollinen) ja itse kirjoittamasi Comtest-testit (valinnainen). Ei class eikä Main-koodia.

Suurin

# demo4teht5

Pienin

# demo4teht5b

Tehtävä 6

Lue ensin: 12. Merkkijonot, Jonoja.cs.

Tehtävä: Tee funktiot VainEkaSana ja PoistaEkaSana. VainEkaSana ottaa parametrina merkkijonon ja palauttaa ensimmäisen sanan, ts. merkkijonon alusta välilyöntiin saakka (välilyöntiä ei oteta mukaan).

PoistaEkaSana ottaa parametrina merkkijonon ja palauttaa kaiken muun paitsi ensimmäisen sanan, ts. ensimmäisestä välilyönnistä eteenpäin (välilyöntiä ei oteta mukaan).

Valinnainen: Voit halutessasi kokeilla ohjelmasi toimintaa oheisella pääohjelmalla, ja myös kopioida omaan koodiisi. Pääohjelmaa ei kuitenkaan palauteta Timiin.

public static void Main(string[] args) 
{
  Console.Write("Anna nimesi muodossa sukunimi etunimi: ");
  string kokonimi = Console.ReadLine();
  string etunimi = PoistaEkaSana(kokonimi);
  string sukunimi = VainEkaSana(kokonimi);
  Console.WriteLine("Etunimesi on siis " + etunimi +  
    " ja sukunimesi " + sukunimi);
}

Vinkki: String-luokan metodit IndexOf, Substring ja Split. Hae MSDN-dokumentaatio ja tutki, miten merkkijono saadaan paloiteltua. Split vaatii taulukon, jota ei vielä ole käsitelty.

Arviointi: Tehtävissä on automaattinen arviointi (0.5 p. + 0.5 p.).

Huom: Alla oleviin vastauslaatikoihin laitetaan vain valmiit funktiot (pakollinen), niihin kuuluvat dokumentaatiot (pakollinen) ja itse kirjoittamasi Comtest-testit (valinnainen). Ei class eikä Main-koodia.

VainEkaSana

# VainEkaSana

PoistaEkaSana

# PoistaEkaSana

Tehtävä 7

Tee kaikki kohdat a-j. Tehtävästä saa yhteensä max 1 p.

Lue ensin: 26.4 Negatiiviset binääriluvut

Johdanto: Useimmiten nykytietokoneissa käytetään sisäisesti negatiivisille kokonaisluvuille niin sanottua kahden komplementtia. Kahden komplementissa positiivinen luku muutetaan negatiiviseksi muuttamalla kaikki bitit "päinvastaisiksi" (1 \(\rightarrow\) 0 ja 0 \(\rightarrow\) 1) ja sitten lisäämällä saatuun lukuun 1.

Alla esimerkki luvun -3 esittämisestä kahden komplementin avulla 8-bittisen luvun avulla.

 3 = 0000 0011, joten 
-3 tehdään kahden komplementtina seuraavasti:
     1)  kaikki bitit päinvastoin = 1111 1100
     2)  +1                       = 1111 1101

Lukua tulkittaessa katsotaan sen aluksi ensimmäinen bitti. Jos se on 1, niin kyseessä on negatiivinen luku ja se muutetaan positiiviseksi ottamalla siitä jälleen kahden komplementti, eli "kääntämällä" kaikki bitit päinvastaisiksi ja lisäämällä lopuksi 1.

Alla on tulkittu binääriluvut 0010 1101 ja 1101 1111, joiden tiedämme edustavan 8-bittisiä kokonaislukuja, missä negatiivisille luvuille on käytössä kahden komplementti.

0010 1101 luku on positiivinen, eli 45
1101 1111 luku on negatiivinen, siis ensin 2:n komplementti
           0010 0000 + 1 = 0010 0001 = 33, eli tulos on -33

Tehtävä 7 a, b, c ja d: (0,4p)

# d3teht1abcd

Kirjoita vastauksesi alla oleviin e)- ja f)-kohtiin muodossa

a) 11-22 = -33

Tehtävä 7 e: (0,1p)

# d3teht1e

Tehtävä 7 f: (0,1p)

# d3teht1f

Tehtävä 7 g: (0,1p)

# d3teht1g

Tehtävä 7 h: (0,1p)

# d3teht1h

Tehtävä 7 i: (0,1p)

# d3teht1i

Tehtävä 7 j: (0,1p)

# d3teht1j

TDD 1

Ensiksi: Tarkista vähintään kahden funktion toiminta automaattisella testillä (ComTest). (1 p.)

Käyttääksesi ComTestiä asenna se tietokoneellesi edellä löytyvän linkin ohjeiden mukaan. Voit varmistaa että asennus on mennyt oikein läpi näin:

  1. Tee uusi Console Application -projekti
  2. Copy-pasteta tämä testikoodi projektiisi
  3. Aja ComTest (tarvittaessa katso ohje)
  4. Jos avautuu alas All tests from Solution ja vihreällä teksti Success, niin kaikki meni oikein. Muussa tapauksessa tutki asennusohjeita uudestaan ja kysy tarvittaessa apua ohjaajilta.

Vastauksena kerro, minkä tehtävän ja minkä funktion/funktioiden toiminnan testasit. Huomaa, että ohjelmia, joissa on pelkkä Main-pääohjelma, ei voida tämän kurssin tiedoilla testata, kuten ei myöskään Jypeli-pelejä. Siksi testaamista tehdään demoissa vain static-funktioille. Tässä demossa sellaisia on tehtävissä 3, 4, 5 ja 6.

# demo4tdd

Jos ComTest ei toimi koneellasi, voit Copy/Pasteta ohjelmia alla olevaan laatikkoon ja testata siinä.

# ComTestPohjaCS

Ville 1

Tee Ville-tehtävät 3.3, 3.5, 3.6. 4.1-4.4. Muista: Villen käyttöohje. Kirjoita lyhyesti mitä opit Ville-tehtävistä ja olivatko tehtävät hyödyllisiä.

# demo4ville1

B1

Tehtävä: Lue seuraavat dokumentaatiot ja aliohjelmien esittelyt. Jokaisessa niissä on jotain outoa. Parannettavaa voi olla (mutta ei välttämättä ole) paluuarvon tyypissä, funktion nimessä, parametrien määrässä ja niiden nimissä tai tyypeissä, tai itse dokumentaatiokommenteissa. Myös kokonaisia sanoja voi puuttua esittelyriviltä tai dokumentaatiosta.

Kirjoita vastauslaatikkoon mitä korjattavaa löysit ylläolevasta koodista. Huomaa, että aliohjelmien toteutusta ei tässä arvioida eikä edes näytetä. Tee tulkintasi dokumentaation ja esittelyrivin perusteella.

Arviointi: Täysiä pisteitä varten jokaisesta kohdasta pitäisi löytyä vähintään kaksi korjattavaa asiaa.

A. Itseisarvo

/// <summary> Funktio palauttaa annetun luvun itseisarvon. </summary>
/// <param name="luku"> Luku, josta itseisarvo halutaan ottaa. </param>
/// <returns> Luvun itseisarvo. </returns>
public static int palautaitseisarvo(double luku)
{
  ...
}
# demo4tehtb1a

B. Lyhyempi sana

/// <summary> Funktio palauttaa kahdesta sanasta lyhyemmän. 
/// Sanojen ollessa yhtä pitkiä palautetaan ensimmäinen. </summary>
/// <param name="sana1"> Ensimmäinen sana. </param>
/// <param name="sana2"> Toinen sana. </param>
/// <returns> Lyhyempi sana. </returns>
void string LyhyempiKahdestaSanasta(char sana1 char sana2)
{
  ...
}
# demo4tehtb1b

C. Palindromi

/// <summary> Funktio kertoo, onko sana palindromi. </summary>
/// <param name="sana"> Tutkittava sana. </param>
/// <returns> Onko palindromi. </returns>
public static string Palindromi(bool)
{
  ...
}
# demo4tehtb1c

B2-3

Tee Jypeli-peli, jossa luodaan pelikentälle satunnaisiin paikkoihin 30 palloa (mielellään satunnaisin värein), joilla on satunnainen säde 5 ja 30 välillä (katso vinkki 1). Kokeile, että toimii. Lisää vielä yksi 40-säteinen valkoinen pallo, jota voi ohjata "tökkimällä" nuolinäppäimillä (katso vinkki 2).

Arviointi: Käytä Set custom points -toimintoa. Hyvästä yrityksestä, johon kuuluu ainakin pallon liikuttelu tai satunnaisten pallojen luonti, voit antaa itsellesi yhden pisteen. Anna itsellesi täydet 2 pistettä molemmat vaatimukset täyttävästä ja hyvin dokumentoidusta vastauksesta.

Vinkki 1: Tutustu Jypelin satunnaisuutta tarjoavaan RandomGen-luokkaan.

Vinkki 2: Ohjainten lisäämiseen voit katsoa apua Pong-tutoriaaleista.

# demo4tehtb2

B4

Voit tehdä A- ja B-kohdat samaan .cs-tiedostoon.

Tehtävä B4.1. Katso char-dokumentaatiota. Mitä sinun on kirjoitettava xxx:n paikalle, jotta alla oleva ohjelma toimisi?

# demo4tehtb3a

Tehtävä B4.2. Tee funktio IsoVaiPieni, joka palauttaa onko parametrina annetun merkkijonon ensimmäinen merkki suuraakkonen (uppercase) vai ei. Jos ensimmäinen merkki on suuraakkonen, palautetaan merkkijono "iso". Jos taas eka merkki ei ole suuraakkonen (myöskään erikoismerkit jne. eivät ole suuraakkosia) palautetaan merkkijono "pieni".

Vinkki: Katso myös luentomoniste.

# demo4tehtb3b

G1

Lisää tehtävän B2-3 pallopeliin ominaisuus, että jos ohjattavalla pallolla osuu toiseen palloon kentän puolivälin yläpuolella, toinen pallo räjähtää ja poistuu pelistä. Pelin tarkoituksena on räjäyttää kaikki pallot.

Vinkki: Jypelin ohjeet

# demo4g1

These are the current permissions for this document; please modify if needed. You can always modify these permissions from the manage page.