merkkijonotaulukon "siivoaminen"

hjelppinkiä kaivataa

Nimitaulukko sisältää nimiä. Osa nimistä on useampaan kertaan.

Nyt nimitaulukko pitäisi siivota siten, että siellä on jokainen nimi vain kerran

Kuinka tuo oikein toteutetaan? Olen yrittänyt vaikka mitä, mutta aina menee siihen pisteeseen ettei tajua miten...

Olisiko jotain vinkkiä...esim. koodin pätkää. hitto kun en muista missä oli erilaisia taulukkojen lajittelu malleja ym ym...

13

507

    Vastaukset

    Anonyymi (Kirjaudu / Rekisteröidy)
    5000
    • hjelppinkiä?

      #include
      #include
      #include


      int main (void)
      {
      char vertailtava[10];
      int i,j=0;
      char keratyt_nimet[6][10]={""};
      char nimitaulukko[6][10]={"Kalle",
      "Pekka",
      "Ari",
      "Pentti",
      "Ari",
      "Kalle"
      };
      printf("Taulukossa: \n");

      for(i=0; i

      • sdsdsdrrwrdssdsd

        For-loopillahan tuo vissiin pitäisi toteuttaa jos teulukkossa alkaa olemaan esiintymiä yhtää nenempää.


      • hjelppinkiä
        sdsdsdrrwrdssdsd kirjoitti:

        For-loopillahan tuo vissiin pitäisi toteuttaa jos teulukkossa alkaa olemaan esiintymiä yhtää nenempää.

        Toimii ainakin jotenkin...

        include
        include
        include


        int main (void)
        {

        int i, j=0;
        char szOperators[6][15]={"Matti", "Seppo", "Kalevi","Esko","Matti","Tero"};
        char szKeratytKuskit[6][15]={""};
        int nKeratytAjomatkat[300]={0};
        char szVerrattava[15];
        char cTalletaTaulukkoon=0;
        char cLoytyi=0;
        char cEiLoytynyt=0;
        int nTalletusKohta=0;

        for(i=0;i


      • myslihattu
        hjelppinkiä kirjoitti:

        Toimii ainakin jotenkin...

        include
        include
        include


        int main (void)
        {

        int i, j=0;
        char szOperators[6][15]={"Matti", "Seppo", "Kalevi","Esko","Matti","Tero"};
        char szKeratytKuskit[6][15]={""};
        int nKeratytAjomatkat[300]={0};
        char szVerrattava[15];
        char cTalletaTaulukkoon=0;
        char cLoytyi=0;
        char cEiLoytynyt=0;
        int nTalletusKohta=0;

        for(i=0;i

        Tässä nyt yksi tapa, C ;
        Tee tarvittavat muutokset C-kieleen, jos on joku koulu työ.

        #include
        using namespace std;
        int main(){
        const int index=6;
        char nimet[index][10]={"Kalle","Pekka","Ari","Pentti","Ari","Kalle"};
        for(int i = 0; i 1 < index; i ){
        for(int j = i 1; j < index; j ){
        if(!strcmp(nimet[i],nimet[j])){
        // duplikaatti löytynyt
        // laitetaan ko. kohta tyhjäksi.
        std::cout


      • myslihattu
        myslihattu kirjoitti:

        Tässä nyt yksi tapa, C ;
        Tee tarvittavat muutokset C-kieleen, jos on joku koulu työ.

        #include
        using namespace std;
        int main(){
        const int index=6;
        char nimet[index][10]={"Kalle","Pekka","Ari","Pentti","Ari","Kalle"};
        for(int i = 0; i 1 < index; i ){
        for(int j = i 1; j < index; j ){
        if(!strcmp(nimet[i],nimet[j])){
        // duplikaatti löytynyt
        // laitetaan ko. kohta tyhjäksi.
        std::cout

        Hieno C palsta jos ei voi edes kieltä kirjoittaa.
        Kun < > merkit puuttuu.

        #include iostream
        using namespace std;
        int main(){
        const int index=6;
        char nimet[index][10]={"Kalle","Pekka","Ari","Pentti","Ari","Kalle"};
        for(int i = 0; i 1 < index; i ){
        for(int j = i 1; j < index; j ){
        if(!strcmp(nimet[i],nimet[j])){
        // duplikaatti löytynyt
        // laitetaan ko. kohta tyhjäksi.
        nimet[j][0] = '\0';
        }
        }
        }
        // katotaan miltä näyttää;
        for(int i = 0; i < index; i ){
        if(nimet[i][0] == '\0'){
        // TÄMÄ INDEKSI ON TYHJÄ
        } else {
        // TULOSTA NIMI taulukosta
        }
        }
        std::cin.get();
        return 0;
        }


    • Kaikkee paskaa!

      Maailmassa on todennäköisesti satojatuhansia samannimisiä henkilöitä, mutta useat Internetin merkittävimpien palveluitten tuottajista ei kuitenkaan atk-maikkasi tavoin ole näin perustavanlaatuista seikkaa hiffannut, vaan kehittelevät toinen toistansa muukamas hienostuneempia keinoja, joilla voivat siivota asiakkaistaan samannimiset pois. Tästä on seurauksena, että jo toinen Einari Epätoivo joutuu ottamaan Internetistä palvelua saadakseen uudeksi nimekseen Einari00001 Epätoivo, jotta palveluntarjojan taulukkoon ei tulisi kahta samannimistä!

      • myslihattu

        Ja tälläset henkilöt eivät pitäisi edes puhua ohjelmointi palstalla.

        Kyseessä on harjoitustehtävä. Jonka tarkoitus on opettaa merkkijonon käyttöä C-kielessä.
        Joten miksi sitä ei kannattaisi opetella?

        Pitäiskö myös ns. for-silmukan pyramidi tehtävät kieltää, koska egyptiläiset rakensi ne jo 4-6000 vuotta sitte?


      • lflkfkfkdkkf

        Totta. Tässä tapauksessa vain oikeasti tuo nimi (ja paljon muutakin) haetaan tiedostoista tuohon taulukkoon ja kerätään ns. "nimen perään". Sovelluksessa kuka tahansa voi olla mikä tahansa niminen.

        Tuo oli vaan palane isompaa ohjelmaa jossa tuo nimitaulukko on muodostettu muualla...tuossa sitä vain siivotaan...

        Mutta joo... jokin "ominaisuus" pitää eri esiintymilllä olla jotta ne voidaan erotella, jos se ei ole nimi, niin sitten sen pitää olla salasana....kirjautumispvm.

        Tässä yritetään kuitenkin opetella.... Kiitoksia kuitnekin kommenteista. Ratkaisukin tuohon oli tosi helppo kun jäähdytteli aivot "happihyppelyllä" pakkasessa. Kun homma jumii niin sitten se jumii....


      • ilkakasjas
        lflkfkfkdkkf kirjoitti:

        Totta. Tässä tapauksessa vain oikeasti tuo nimi (ja paljon muutakin) haetaan tiedostoista tuohon taulukkoon ja kerätään ns. "nimen perään". Sovelluksessa kuka tahansa voi olla mikä tahansa niminen.

        Tuo oli vaan palane isompaa ohjelmaa jossa tuo nimitaulukko on muodostettu muualla...tuossa sitä vain siivotaan...

        Mutta joo... jokin "ominaisuus" pitää eri esiintymilllä olla jotta ne voidaan erotella, jos se ei ole nimi, niin sitten sen pitää olla salasana....kirjautumispvm.

        Tässä yritetään kuitenkin opetella.... Kiitoksia kuitnekin kommenteista. Ratkaisukin tuohon oli tosi helppo kun jäähdytteli aivot "happihyppelyllä" pakkasessa. Kun homma jumii niin sitten se jumii....

        "Mutta joo... jokin "ominaisuus" pitää eri esiintymilllä olla jotta ne voidaan erotella, jos se ei ole nimi, niin sitten sen pitää olla salasana....kirjautumispvm."

        Ei käy (pohdi itse miksi ei). Ratkaisu on yksilöllinen id (unique identifier).
        http://en.wikipedia.org/wiki/Unique_identifier#Computing

        Duplikaattien poisto on perusjuttuja, jolle on joissakin kielissä valmiina funktiot/metodit.

        Tuossa C :n vektorille ratkaisu ja selitys:
        http://en.allexperts.com/q/C-1040/Delete-duplicate-elements-vector.htm

        Ja vaikkapa Rubyssa on uniq ja uniq! (! tarkoittaa että muuttaa alkuperäistä taulukkoa) metodit:
        http://www.ruby-doc.org/core/classes/Array.html#M000276

        Toki harjoituksen vuoksi kannattaa tehdä oma versio.


      • ilkakasjas
        lflkfkfkdkkf kirjoitti:

        Totta. Tässä tapauksessa vain oikeasti tuo nimi (ja paljon muutakin) haetaan tiedostoista tuohon taulukkoon ja kerätään ns. "nimen perään". Sovelluksessa kuka tahansa voi olla mikä tahansa niminen.

        Tuo oli vaan palane isompaa ohjelmaa jossa tuo nimitaulukko on muodostettu muualla...tuossa sitä vain siivotaan...

        Mutta joo... jokin "ominaisuus" pitää eri esiintymilllä olla jotta ne voidaan erotella, jos se ei ole nimi, niin sitten sen pitää olla salasana....kirjautumispvm.

        Tässä yritetään kuitenkin opetella.... Kiitoksia kuitnekin kommenteista. Ratkaisukin tuohon oli tosi helppo kun jäähdytteli aivot "happihyppelyllä" pakkasessa. Kun homma jumii niin sitten se jumii....

        Tietenkin nimi käy esim. kun käyttäjä pakotetaan valitsemaan uniikki käyttäjätunnus (kuten moni nettirekisteröinti toimii).


      • myslihattu
        ilkakasjas kirjoitti:

        "Mutta joo... jokin "ominaisuus" pitää eri esiintymilllä olla jotta ne voidaan erotella, jos se ei ole nimi, niin sitten sen pitää olla salasana....kirjautumispvm."

        Ei käy (pohdi itse miksi ei). Ratkaisu on yksilöllinen id (unique identifier).
        http://en.wikipedia.org/wiki/Unique_identifier#Computing

        Duplikaattien poisto on perusjuttuja, jolle on joissakin kielissä valmiina funktiot/metodit.

        Tuossa C :n vektorille ratkaisu ja selitys:
        http://en.allexperts.com/q/C-1040/Delete-duplicate-elements-vector.htm

        Ja vaikkapa Rubyssa on uniq ja uniq! (! tarkoittaa että muuttaa alkuperäistä taulukkoa) metodit:
        http://www.ruby-doc.org/core/classes/Array.html#M000276

        Toki harjoituksen vuoksi kannattaa tehdä oma versio.

        ""Tuossa C :n vektorille ratkaisu ja selitys:
        http://en.allexperts.com/q/C-1040/Delete-duplicate-elements-vector.htm""

        Miksi nykyään kaikki tehdään vektoreilla? Hirvee härdelli.
        Linkitetty lista, linked list mieluiten kaksisuuntainen olis kaikista optimaalisin tähän :)
        Senku deletois nimen pois listasta.


      • myslihatty
        myslihattu kirjoitti:

        ""Tuossa C :n vektorille ratkaisu ja selitys:
        http://en.allexperts.com/q/C-1040/Delete-duplicate-elements-vector.htm""

        Miksi nykyään kaikki tehdään vektoreilla? Hirvee härdelli.
        Linkitetty lista, linked list mieluiten kaksisuuntainen olis kaikista optimaalisin tähän :)
        Senku deletois nimen pois listasta.

        Lisäys
        Ja jos nimiä on järjetön määrä kuten vaikka väestörekisteri, ilman oraclee, sql:ää. Niin silloin pitää tarraa kiinni puusta ;)
        (mutta todellisuudessa tietokanta taitaisi hoitaa ton asian)


      • myslihattu kirjoitti:

        ""Tuossa C :n vektorille ratkaisu ja selitys:
        http://en.allexperts.com/q/C-1040/Delete-duplicate-elements-vector.htm""

        Miksi nykyään kaikki tehdään vektoreilla? Hirvee härdelli.
        Linkitetty lista, linked list mieluiten kaksisuuntainen olis kaikista optimaalisin tähän :)
        Senku deletois nimen pois listasta.

        > Linkitetty lista, linked list mieluiten kaksisuuntainen olis kaikista optimaalisin tähän :)

        olet oikeassa: taulukoissa tuhlataan tilaa tai niistä loppuu tila kesken :-( linkitetty rakenne ei sido käsiä jos vaan keskusmuisti riittää

        nopea käsittely sitten isoissa aineistoissa taitaa tosiaan mennä linkitettyjen binääripuiden käsittelyksi ... mutta pienet tavallisinakin ... ja jollei ole kiire niin aputiedostojen kautta


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

    Luetuimmat keskustelut

    1. SDP jo 100 % suositumpi kuin persut

      Kertoo Hesarin uusin kannatuskysely. Demareiden kannatus on miltei tuplat verrattuna persuihinl. Suomen kansa ei selväst
      Maailman menoa
      89
      10652
    2. Voiko normaali ihminen ryhtyä vasemmistolaiseksi?

      Tätä jäin pohdiskelemaan.
      Maailman menoa
      245
      4566
    3. SDP haluaa 40 000 nettomaahanmuuttajaa

      SDP:n Suunnanmuutos-vaihtoehtobudjetissa, käy ilmi, että demarit itse asiassa vaativat räjähdysmäistä ”työperäisen” maah
      Maailman menoa
      163
      3943
    4. Orpo: Velkajarrua vastustavaa puoluetta vaikea ajatella hallitukseen

      No Minja Koskelan kommunistipuolue jäi ulos tuosta. Kaikki eduskuntapuolueet vasemmistoliittoa lukuun ottamatta sopivat
      Maailman menoa
      167
      3439
    5. PS ylivoimainen nousija myös HS:n gallupissa, SDP laskee taas

      https://www.verkkouutiset.fi/a/hs-gallup-sdpn-suosio-laskee-ps-nousussa/#0a7d2507 Ylivoimainen viime kuukausien nousija
      Maailman menoa
      71
      3259
    6. Valtavasti suomalaisia asunnottomina, mutta ei yhtään somalia

      tai muuta kehitysmaalaista. Mites tässä näin kävi? Tiedän hyvin, että esim. somaleita lentää ulos mm. Hekan asunnoista,
      Maailman menoa
      69
      3020
    7. Mikä tämä henkilö mahtaa touhuta Parkanossa

      Kamalaa https://www.ylasatakunta.fi/teksti/pirkanmaan-karajaoikeus-vangitsi-koiran-tappamisesta-epaillyn-6.68.127794.b58
      Parkano
      32
      2712
    8. Ikävä sinua mies

      Vuosia kuluu, mutta tunteet ei ole hävinnyt. Tasoittuneet toki, kun ei olla nähty. Järki palannut päähän kuitenkin. Se i
      Ikävä
      27
      2280
    9. Hienoa! Eduskunta luopui käteisen käytöstä

      Nyt tuo sama muutos pitää saada myös muuhun yhteiskuntaan. Käteistähän ei tarvitse tänä päivänä enää kuin rikolliset.
      Maailman menoa
      65
      1766
    10. Kiinnostaa - ei kiinnosta - kiinnostaapas

      Selittäkää hämmentyneelle miksi miehiä ei ikinä kiinnosta silloin, kun sitä olisi itsekin kiinnostunut? Sitten kun siirt
      Sinkut
      164
      1510
    Aihe