graafin kytkentälista

Linux-käyttäjä

Hei Linuxin ja g :n käyttäjät!
seuraavassa on C -ohjelma, joka tallentaa
graafin kytkentälista-tyyppiseen tietorakenteeseen.
kääntäjä on g 4.1.2. ongelmana on
muistialueen ylitys -virhe, kun syötteenä on
esimerkiksi 0 11 22 3Q.

voisiko joku paikantaa virheet. tämä lienee
helppoa Visual C :n debuggerilla. minulla on
käytössä vain hankala ddd ja gdb.

graafin kytkentälista on taulukko, jonka alkiot
sisältävät graafin toisiinsa yhteydessä olevat
pisteet. (graafi on joukko pisteitä ja niitä
yhdistäviä kaaria). alkiot muodostavat kustakin
taulukon alkiosta alkavan alkioiden yksisuuntaisen
listan. (struct alkio) esim. syöte 0 1 luo
taulukkoon listan, jonka arvot ovat 0 (alkupiste)
ja 1 (0-pisteeseen liittyneiden pisteiden joukko.

kiitos neuvoista

2

375

    Vastaukset

    Anonyymi (Kirjaudu / Rekisteröidy)
    5000
    • Linux-käyttäjä

      tässä lähdekoodi:

      #include
      #include // malloc() ja atoi()
      #include // scanf()
      #include // assert()
      using namespace std;

      struct alkio
      {
      int arvo;
      struct alkio* seuraava;
      };

      int main()
      {
      struct alkio* lista[100]; // sadan alkion lista (osoittimia alkioihin)
      char syote[4]; int i;
      int alkupiste = 0, loppupiste = 0;
      struct alkio* solmu = NULL;
      struct alkio* apusolmu = NULL;
      for (i = 0; i < 100; i )
      lista[i] = NULL;
      syote[0] = syote[1] = syote[2] = '\0';

      while(1)
      {
      scanf("%s", &syote);
      if (syote[0] == 'Q')
         break;
      alkupiste = atoi(syote);
      scanf("%s", &syote);
      loppupiste = atoi(syote);

      if (lista[alkupiste] == NULL)
      {
      lista[alkupiste] = (alkio*)malloc(sizeof(alkio));
      lista[alkupiste]->arvo = loppupiste;
      lista[alkupiste]->seuraava = NULL;
      }
      else // listassa on vähintään yksi alkio kohdassa lista[alkupiste]
      {
      solmu = lista[alkupiste];
      while(solmu->seuraava)
      solmu = solmu->seuraava;
      assert(solmu->seuraava == NULL); // nyt solmu osoittaa listan
                     // viimeiseen alkioon
      struct alkio* uusiSolmu = (alkio*)malloc(sizeof(alkio));
      solmu->seuraava = uusiSolmu;
      uusiSolmu->seuraava = NULL;
      solmu->arvo = loppupiste;
      }
      }
      solmu = lista[0];
      for (i = 0; i < 10; i )
      {
      cout seuraava)
      {
      apusolmu = solmu->seuraava;
         cout arvo seuraava;
      free( (void*)solmu);
      solmu = apusolmu;
      }
      free( (void*)solmu);
      }
      solmu = lista[ i];
      }
      }

    • Aku Ankka

      Ei mulla tuu muistialueen ylitystä:
      0 1
      1 2
      2 3
      Q
      0->1->
      1->1->
      2->2->
      3->3->
      4->
      5->
      6->
      7->
      8->
      9->

      g versio 4.1.3.

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

    Luetuimmat keskustelut

    1. Mistä puhuitte viimeksi kun näitte

      Kerro yksi aiheista
      Ikävä
      107
      7793
    2. 114
      6098
    3. Se on hyvästi

      Toivottavasti ei tavata.
      Ikävä
      83
      5207
    4. Olenko saanut sinut koukkuun?

      Hyvä. Rakastan sua.
      Ikävä
      141
      4563
    5. Alavuden sairaala

      Säästääkö Alavuden sairaala sähkössä. Kävin Sunnuntaina vast. otolla. Odotushuone ja käytävä jolla lääkäri otti vastaan
      Ähtäri
      11
      3240
    6. Sisäsiittosuus

      Tämän kevään ylioppilaista 90% oli sama sukunimi?
      Suomussalmi
      62
      3034
    7. Miksi sä valitsit

      Juuri minut sieltä?
      Ikävä
      58
      2948
    8. Törkeää toimintaa

      Todella törkeitä kaheleita niitä on Ylivieskassakin. https://www.ess.fi/uutissuomalainen/8570818
      Ylivieska
      10
      2464
    9. Kerro nyt rehellisesti fiilikset?

      Rehellinem fiilis
      Suhteet
      61
      2447
    10. Hei........

      Pelkkä sun näkeminen saa mut hymyilemään pitkin iltaa. Oot niin 🤩😘 Edellinen poistettiin.
      Ikävä
      56
      2076
    Aihe