C alkeet ongelma while lauseen kanssa

keijokoodari12

Eli tarkoitus olisi tehdä ohjelma, joka kysyy oppilaiden koearvosanoja (kokonaisluvut 4-10 käytössä) ja laskee syötettyjen arvosanojen keskiarvon. Ohjelman tulee ottaa vastaan arvosanoja, kunnes arvosanojen syöttö lopetetaan negatiivisella kokonaisluvulla. Lopuksi ohjelma tulostaa arvosanojen lukumäärän sekä lasketun keskiarvon, joka tulostetaan kahden desimaalin tarkkuudella.

Ohjelman tulisi tulostaa seuraavasti:
Esimerkkitulostus

Ohjelma laskee syötettyjen arvosanojen keskiarvon.
Lopetus negatiivisella kokonaisluvulla.
Anna arvosana (4-10):4
Anna arvosana (4-10):5
Anna arvosana (4-10):6
Anna arvosana (4-10):9
Anna arvosana (4-10):7
Anna arvosana (4-10):-1
Ohjelmaan syötetty 5 arvosanaa.
Arvosanojen keskiarvo: 6.20

En saa tekemääni koodia toimimaan enkä oikein ymmärrä mikä siinä on vialla.
Voi myös olla että olen ihan pihalla tässä hommassa. Epätoivosesti yrittänyt maalaisjärjellä ratkoa tätä.

Koodi:
###########
#include

int main()
{
int i = 0;
int luku, ka, summa, maara;

printf("Ohjelma laskee syötettyjen arvosanojen keskiarvon.\nLopetus negatiivisella kokonaisluvulla.\n");
while(luku >= 0) {
printf("Anna arvosana (4-10):");
scanf("%d",&luku);
summa = luku;
i ;

}
maara = i - 1;
ka = summa / maara;
printf("Ohjelmaan syötetty %d arvosanaa.\n", maara);
printf("Arvosanojen keskiarvo: %.2d", ka);

return 0;
}
###########

11

428

    Vastaukset

    Anonyymi (Kirjaudu / Rekisteröidy)
    5000
    • eternal_loop

      Tuossa on aika monta virhettä:

      ka pitäisi olla float.
      Summaa ei alustettu nollaksi.
      Muunnos jotain näin: ka = (float) summa / maara;
      Ja silloin %.2d olisi tietysti %.2f

      Lisäksi summaa lasketaan vaikka luku on muuta kuin 4-10 esim -1 tai 3.

      Turha i-muuttuja mielellään pois ja mitä tapahtuu jos kirjoittaa vaikka pari kirjainta... ei kai jää ikuiseen silmukkaan.

    • keijokoodari12

      Kiitos paljon avusta. Sain sen nyt toimimaan niin kuin piti.

      • eternal_loop

        Jos saat mallivastauksen, niin laitapa tänne.


    • sdfsfsfsdfsfsfds

      Tosiaan C:n standardikirjastoa ei todellakana ole suunniteltu konsolikäyttöliittymien luomiseen joten tämän kaltaiset koulutehtävät ovat hieman idioottimaisia.

      Datan syöttäminen pitäisi toteuttaa enemminkin argumentteina.


      Ncurses ja muut curses kirjastot ovat sitten varsinaisten käyttöliittymien tekoon.

      • eternal_loop

        "Datan syöttäminen pitäisi toteuttaa enemminkin argumentteina."

        Nimenomaan ja jos tehtävä vielä olisi: "Tee ohjelma joka laskee argumenttiensa keskiarvon".

        Ratkaisu:

        #include

        int main( int argc, char *argv[] )
        {
            int i, count = 0;
            float num, sum = 0.0;

            for ( i = 1; i < argc; i ) {
                if ( sscanf(argv[i], "%f", &num) == 1 ) {
                   sum = num;
                   count ;
                }
            }

            printf( "Lukuja löytyi %d kpl\n", count );
            printf( "Keskiarvo: %.2f\n", sum / count );

            return 0;
        }

        Ohjelma on näin selkeämpi, näppärämpi käyttää, monipuolisempi ja yleisempi ratkaisu. Ja tietysti bugiton (luultavasti).

        Toimii oikein mm. näillä syötteillä:
        ./keskiarvo 4 5 6
        ./keskiarvo 4.9999 5 jdja 6
        ./keskiarvo `cat keskiarvo.c` #tiedoston syöttö

        Ohoh, tuohan muistuttaa jo oikeaa komentoriviohjelmaa. Ja siihen kun vielä myöhemmin lisää optioina alarajan ja ylärajan niin nuubi-koodari tuntisi että tulipa opittua jotain järkevää.


      • Jepajee...
        eternal_loop kirjoitti:

        "Datan syöttäminen pitäisi toteuttaa enemminkin argumentteina."

        Nimenomaan ja jos tehtävä vielä olisi: "Tee ohjelma joka laskee argumenttiensa keskiarvon".

        Ratkaisu:

        #include

        int main( int argc, char *argv[] )
        {
            int i, count = 0;
            float num, sum = 0.0;

            for ( i = 1; i < argc; i ) {
                if ( sscanf(argv[i], "%f", &num) == 1 ) {
                   sum = num;
                   count ;
                }
            }

            printf( "Lukuja löytyi %d kpl\n", count );
            printf( "Keskiarvo: %.2f\n", sum / count );

            return 0;
        }

        Ohjelma on näin selkeämpi, näppärämpi käyttää, monipuolisempi ja yleisempi ratkaisu. Ja tietysti bugiton (luultavasti).

        Toimii oikein mm. näillä syötteillä:
        ./keskiarvo 4 5 6
        ./keskiarvo 4.9999 5 jdja 6
        ./keskiarvo `cat keskiarvo.c` #tiedoston syöttö

        Ohoh, tuohan muistuttaa jo oikeaa komentoriviohjelmaa. Ja siihen kun vielä myöhemmin lisää optioina alarajan ja ylärajan niin nuubi-koodari tuntisi että tulipa opittua jotain järkevää.

        Todellakin juuri näin. Tämä on oikea ratkaisutapa standardikirjastolla.


    • 23423423

      Tosiaan tämän tehtävän on laatinut joko henkilö joka ei tiedä mitää C-ohjelmoinnista tai sitten henkilö joka on vittuillakseen pistänyt kurssilaiselle moisen sudenkuopan ratkaistavaksi.

      Paras ratkaisu olisi muuttaa koko datan haku systeemi tai sitten käyttää curses kirjastoa.

      • eternal_loop

        "Tosiaan tämän tehtävän on laatinut joko henkilö joka ei tiedä mitää C-ohjelmoinnista tai sitten henkilö joka on vittuillakseen pistänyt kurssilaiselle moisen sudenkuopan ratkaistavaksi."

        Toivokaamme hartaasti jälkimmäistä...


    • 22 22 22 22 22

      tuohan on ihan normaali ohjelmoinnin peruskurssin tehtäviä, joka todennäköisesti tehdään siinä vaiheessa kun opiskellaan while-lausetta.

      • dsfsfsdfs

        Onko oikein vaatia aloittelijalta kiertämään inhottavia ongelmia jotka syntyvät siitä kun käsketään käyttää peruskirjastoa sellaiseen tarkoitukseen mihin sitä ei ole lainkaan suunniteltu.


    Ketjusta on poistettu 0 sääntöjenvastaista viestiä.

    Luetuimmat keskustelut

    1. Aivosyöpää sairastava Olga Temonen TV:ssä - Viimeinen Perjantai-keskusteluohjelma ulos

      Näyttelijä-yrittäjä Olga Temonen sairastaa neljännen asteen glioomaa eli aivosyöpää, jota ei ole mahdollista leikata. Hä
      Maailman menoa
      91
      2910
    2. Pelotelkaa niin paljon kuin sielu sietää.

      Mutta ei mene perille asti. Miksi Venäjä hyökkäisi Suomeen? No, tottahan se tietenkin on jos Suomi joka ei ole edes soda
      Maailman menoa
      299
      1686
    3. Mikä saa ihmisen tekemään tällaista?

      Onko se huomatuksi tulemisen tarve tosiaan niin iso tarve, että nuoruuttaan ja tietämättömyyttään pilataan loppuelämä?
      Sinkut
      246
      1557
    4. Minkä merkkisellä

      Autolla kaivattusi ajaa? Mies jota kaipaan ajaa Mersulla.
      Ikävä
      87
      1391
    5. IL - VARUSMIEHIÄ lähetetään jatkossa NATO-tehtäviin ulkomaille!

      Suomen puolustuksen uudet linjaukset: Varusmiehiä suunnitellaan Nato-tehtäviin Puolustusministeri Antti Häkkänen esittel
      Maailman menoa
      402
      1384
    6. Nyt kun Pride on ohi 3.0

      Edelliset kaksi ketjua tuli täyteen. Pidetään siis edelleen tämä asia esillä. Raamattu opettaa johdonmukaisesti, että
      Luterilaisuus
      400
      1307
    7. Kiitos nainen

      Kuitenkin. Olet sitten ajanmerkkinä. Tuskin enää sinua näen ja huomasitko, että olit siinä viimeisen kerran samassa paik
      Tunteet
      2
      1089
    8. Esko Eerikäinen tatuoi kasvoihinsa rakkaan nimen - Kärkäs kommentti "Ritvasta" lävähti somessa

      Ohhoh! Esko Eerikäinen on ottanut uuden tatuoinnin. Kyseessä ei ole mikä tahansa kuva minne tahansa, vaan Eerikäisen tat
      Suomalaiset julkkikset
      38
      1037
    9. Hyväksytkö sinä sen että päättäjämme ei rakenna rauhaa Venäjän kanssa?

      Vielä kun sota ehkäpä voitaisiin välttää rauhanponnisteluilla niin millä verukkeella voidaan sanoa että on hyvä asia kun
      Maailman menoa
      329
      874
    10. Miksi Purra-graffiti ei nyt olekkaan naisvihaa?

      "Pohtikaapa reaktiota, jos vastaava graffiti olisi tehty Sanna Marinista", kysyy Tere Sammallahti. Helsingin Suvilahden
      Maailman menoa
      257
      855
    Aihe