while ja if - kuinka käyttää tässä tapauksessa?

Anonyymi

Hei,

Minun pitäisi saada ohjelmasta poistettua suurin ja pienin luku. Käyttäjä siis syöttää viisi lukua, joista suoritetaan laskutoimitus, mutta tästä laskutoimituksesta (eli noista viidestä luvusta) pitäisi jättää pois suurin ja pienin.

Viiden luvun syöttyö on tehty while silmukkaa höydyntäen.

Miten suosittelisitte suorittamaan tuon lukujen poisjätön? Ehkä jollain if:illä? Mutta mikä if:n ehto voisi olla, kun tiedossa ei ole mitä lukuja käyttäjä syöttää?

17

762

    Vastaukset

    Anonyymi (Kirjaudu / Rekisteröidy)
    5000
    • Anonyymi

      Kerää kaikki luvut ensin array-muuttujaan, sitten järjestä array pienimmästä suurimpaan ja poista lopuksi pienin ja suurin ennen laskutoimituksia.

      • Anonyymi

        Jos lukuja ei muuten ole tarpeen järjestää, niin tuo on aivan tarpeettoman raskas tapa pudottaa pienin ja suurin luku pois. Toki jos kyse on vain viidestä luvusta, niin eihän sillä mitään väliä oikeasti ole, mutta ihan periaatteen vuoksi suosisin tehokkaampaa algoritmia.

        Esimerkiksi tyyliin: (Oletaan, että nuo luvut on listassa luvut.)
        int suurimmanpaikka = 0
        int pienimmanpaikka = 0
        for( i = 1; i < luvut.lentght(); i )
        {
        if (luvut[i] > luvut[suurimmanpaikka])
        {
        suurimmanpaikka = i;
        }
        if (luvut[i] < luvut[pienimmanpaikka])
        {
        pienimmanpaikka = i;
        }
        }

        Ja sitten poistat listan kohdissa pienimmanpaikka ja suurimmanpaikka olevat luvut tai vain jätät laskematta ne mukaan.


      • Anonyymi
        Anonyymi kirjoitti:

        Jos lukuja ei muuten ole tarpeen järjestää, niin tuo on aivan tarpeettoman raskas tapa pudottaa pienin ja suurin luku pois. Toki jos kyse on vain viidestä luvusta, niin eihän sillä mitään väliä oikeasti ole, mutta ihan periaatteen vuoksi suosisin tehokkaampaa algoritmia.

        Esimerkiksi tyyliin: (Oletaan, että nuo luvut on listassa luvut.)
        int suurimmanpaikka = 0
        int pienimmanpaikka = 0
        for( i = 1; i < luvut.lentght(); i )
        {
        if (luvut[i] > luvut[suurimmanpaikka])
        {
        suurimmanpaikka = i;
        }
        if (luvut[i] < luvut[pienimmanpaikka])
        {
        pienimmanpaikka = i;
        }
        }

        Ja sitten poistat listan kohdissa pienimmanpaikka ja suurimmanpaikka olevat luvut tai vain jätät laskematta ne mukaan.

        Jaha. Sisennykset näköjään katosivat. Koettakaa kestää.


      • Anonyymi

        Lopeta jo kun et osaa!


      • Anonyymi
        Anonyymi kirjoitti:

        Lopeta jo kun et osaa!

        Listan järjestäminen on aina vähintään O(n log(n)) -algoritmi. Pienimmän ja suurimman alkion etsintä ilman järjestämistä on helppo toteuttaa lineaarisesti (O(n)), joten listan tarpeeton järjestäminen on selvästikin huono ratkaisu.


    • Anonyymi

      Kiitos vastauksesta! Koitin tutkia tuota arraytä netistä, mutta en nyt ihan päässyt kärrylle, kuinka se tulisi upottaa tuonne koodiin. Onko tähän vielä jotain vinkkiä tai hyväksyi havaittua ohjesivustoa?

    • Anonyymi

      Jos on varaa tuhlata resursseja, niin varaa muuttujat pienimmälle ja suurimmalle luvulle, ja poistaa lopuksi niiden vaikutuksen lopputulokseen.

    • Anonyymi
      • Anonyymi

        Suurimman ja pienimmän luvun selvittämiseen ei tosin tarvita mitään taulukkoja.


      • Anonyymi

        Laiton linkin koodista sovelletun version pastebin sivulle: https://pastebin.com/xYNG5DXS

        Nyt siinä on suurimman ja pienimmän poisto ja jäljelle jääneiden lukujen summa mukana, mutta edelleenkin while puuttuu.


      • Anonyymi
        Anonyymi kirjoitti:

        Laiton linkin koodista sovelletun version pastebin sivulle: https://pastebin.com/xYNG5DXS

        Nyt siinä on suurimman ja pienimmän poisto ja jäljelle jääneiden lukujen summa mukana, mutta edelleenkin while puuttuu.

        Koska kaikki eivät kuitenkaan osaa tai viitsi ruveta c-ohjelmia kääntämään, laitoin myös kuvan, joka näyttää miten ohjelma toimii:
        https://s1.gifyu.com/images/Nimeamaton-ikkuna_201.png


    • Anonyymi

      Jos taulukkoa meinaat käyttää, niin muista varata sille tila dynaamisesti, jottei kulu suotta pinomuisti. Esimerkiksi viidelle integerille näin stdlib.h:n malloc()-funktion avulla:

      #define KOKO 5
      int *taulukko = NULL;
      taulukko = (int *)malloc(KOKO * sizeof(int));

      • Anonyymi

        EHKÄ kannattaa tarkistaa tuo ohje, hirveesti pukkasi virheitä, kun tein ohjeesi mukaan.

        : varoitus: datamäärittelyllä ei ole tyyppiä eikä tallennusluokkaa
        varoitus: ”taulukko”:n esittelyssä tyyppi on oletuksena ”int” [-Wimplicit-int]
        virhe: ristiriitaiset tyypit ”taulukko”:lle
        huom: ”taulukko”:n edellinen määrittely oli täällä
        varoitus: funktio ”malloc” esitelty implisiittisesti [-Wimplicit-function-declaration]
        varoitus: sisäisen funktion ”malloc” yhteensopimaton implisiittinen esittely
        huom: include ”<stdlib.h>” or provide a declaration of ”malloc”
        varoitus: initialization of ”int” from ”int *” makes integer from pointer without a cast [-Wint-conversion]
        virhe: alustusalkio ei ole vakio


      • Anonyymi

        Tuosta tulikin mieleen että onkos pinon koolle joku raja? Rajoittaako sitä vain fyysisen muistin koko?


      • Anonyymi
        Anonyymi kirjoitti:

        EHKÄ kannattaa tarkistaa tuo ohje, hirveesti pukkasi virheitä, kun tein ohjeesi mukaan.

        : varoitus: datamäärittelyllä ei ole tyyppiä eikä tallennusluokkaa
        varoitus: ”taulukko”:n esittelyssä tyyppi on oletuksena ”int” [-Wimplicit-int]
        virhe: ristiriitaiset tyypit ”taulukko”:lle
        huom: ”taulukko”:n edellinen määrittely oli täällä
        varoitus: funktio ”malloc” esitelty implisiittisesti [-Wimplicit-function-declaration]
        varoitus: sisäisen funktion ”malloc” yhteensopimaton implisiittinen esittely
        huom: include ”<stdlib.h>” or provide a declaration of ”malloc”
        varoitus: initialization of ”int” from ”int *” makes integer from pointer without a cast [-Wint-conversion]
        virhe: alustusalkio ei ole vakio

        Joo tosta puuttuu tietenkin kirjastot ja main-funktio. Luulin sinun perusjutut jo tietävän. Tossa vaadittujen kikkareiden kanssa (tallennettu nimellä 'taulukko.c'):

        #include <stdio.h>
        #include <stdlib.h>

        #define KOKO 5

        int main(void) {
          int *taulukko = NULL;
          taulukko = (int *)malloc(KOKO * sizeof(int));
          printf("Taulukon osoite: %p\n", taulukko);
          free(taulukko);
        }
        /*
        jorma@kone:~$ gcc taulukko.c -o taulukko
        jorma@kone:~$ ./taulukko
        Taulukon osoite: 0x55eeda2a42a0
        */

        Pinomuistin koon näkee linux-pohjaissa esim komennolla 'ulimit -s'.


      • Anonyymi
        Anonyymi kirjoitti:

        Joo tosta puuttuu tietenkin kirjastot ja main-funktio. Luulin sinun perusjutut jo tietävän. Tossa vaadittujen kikkareiden kanssa (tallennettu nimellä 'taulukko.c'):

        #include <stdio.h>
        #include <stdlib.h>

        #define KOKO 5

        int main(void) {
          int *taulukko = NULL;
          taulukko = (int *)malloc(KOKO * sizeof(int));
          printf("Taulukon osoite: %p\n", taulukko);
          free(taulukko);
        }
        /*
        jorma@kone:~$ gcc taulukko.c -o taulukko
        jorma@kone:~$ ./taulukko
        Taulukon osoite: 0x55eeda2a42a0
        */

        Pinomuistin koon näkee linux-pohjaissa esim komennolla 'ulimit -s'.

        ulimit komento näyttää ympäristömuuttujaan sijoitetun pinon koon, jos se tuntuu pieneltä sama komento myös asettaa uuden rajan

        ulimit -s 16384

        mutta malloc() varaa maksimissaan 16711568 tavua, alustamatta varattua tilaa nolla arvolla, kuten calloc() funktio tekee.

        HUOM: en testannut tiedon paikkaansa pitävyyttä, mutta uskon siihen kunnes toisin todistetaan.


      • Anonyymi
        Anonyymi kirjoitti:

        ulimit komento näyttää ympäristömuuttujaan sijoitetun pinon koon, jos se tuntuu pieneltä sama komento myös asettaa uuden rajan

        ulimit -s 16384

        mutta malloc() varaa maksimissaan 16711568 tavua, alustamatta varattua tilaa nolla arvolla, kuten calloc() funktio tekee.

        HUOM: en testannut tiedon paikkaansa pitävyyttä, mutta uskon siihen kunnes toisin todistetaan.

        Calloc():ia minäkin käytin ennen vanhaan C-kielellä enemmän ohjelmoidessa. Saattaa olla vähän hitaampi kuin malloc(). Ja tarvitsee tietysti yhden parametrin enemmän. Hyvä tietää kuitenkin funktioiden erot.

        String.h-kirjastosta löytyy vielä memset(), jolla voi tallentaa muistiin jotain tiettyä arvoa.


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

    Luetuimmat keskustelut

    1. Mitä siellä ABC on tapahtunut

      Tavallista isompi operaatio näkyy olevan kyseessä.
      Alajärvi
      189
      7826
    2. Klaukkalan onnettomuus 4.4

      Klaukkalassa oli tänään se kolmen nuoren naisen onnettomuus, onko kellään mitään tietoa mitä kävi tai ketä onnettomuudes
      Nurmijärvi
      94
      4041
    3. Kuvaile elämäsi naista

      Millainen hän on? Mikä tekee hänestä sinulle erityisen?
      Ikävä
      68
      2652
    4. Kolari Klaukkala

      Kaksi teinityttö kuoli. Vastaantulijoille ei käynyt mitenkään. Mikä auto ja malli telineillä oli entä se toinen auto? Se
      Nurmijärvi
      74
      1692
    5. Ukraina ja Zelenskyn ylläpitämä sota tuhoaa Euroopan, ei Venäjä

      Mutta tätä ei YLE eikä Helsingin Sanomat kerto.
      Maailman menoa
      393
      1616
    6. Kuvaile elämäsi miestä

      Millainen hän on? Mikä tekee hänestä sinulle erityisen?
      Ikävä
      64
      1508
    7. Ooo! Kaija Koo saa kesämökille öky-rempan:jättimäinen terde, poreallas... Katso ennen-jälkeen kuvat!

      Wow, nyt on Kaija Koon mökkipihalla kyllä iso muutos! Miltä näyttää, haluaisitko omalle mökillesi vaikkapa samanlaisen l
      Kesämökki
      20
      1476
    8. Toivoisin, että lähentyisit kanssani

      Tänään koin, että välillämme oli enemmän. Kummatkin katsoivat pidempään kuin tavallisesti toista silmiin. En tiedä mistä
      Ikävä
      17
      1141
    9. Kevyt on olo

      Tiedättekö, että olo kevenee kummasti, kun päästää turhista asioista tai ihmisistä irti! Tämä on hyvä näin <3
      Ikävä
      84
      1068
    10. Olisinpa jo siellä, otatkohan minut vastaan

      Olisitpa lähelläni ja antaisit minun maalata sinulle kuvaa siitä kaikesta ikävästä, tuskasta, epävarmuudesta ja mieleni
      Ikävä
      79
      1060
    Aihe