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
graafin kytkentälista
2
390
Vastaukset
- 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
- 487956
Tulipalossa henkilövahinkoja, itsenäisyyspäivä alkoi huonosti, poliisi tiedottaa lisää
Savonlinna https://www.como.fi/uutiset/savonlinna-henkilovahinkoja-tulipalossa-poliisi-tiedottaa-lisaa/1075944Oletko keskustellut kaivatustasi muiden
Kanssa lähiaikoina? Jos, onko keskustelu ollut positiivista tai negatiivista? Vaikuttaako keskustelut mielipiteeseesi ka593869Ennen ei ollut persuja ja työttömyyttä, lääkäriinkin pääsi
Ennen oli kaikilla töitä Kauppiaille kelpasi kun saivat voittoa Yritystukia ei ollut Lääkäriin pääsi kaikki haluklaat Nu913839- 983579
- 553223
Kyllä on Vasemmistoliitosta Koskelan johdolla tullut todellinen ääripuolue
se on niin tulipunainen kuin olla voi, ja selvästi haluaa jatkuvasti eripuraa, ja repiä kansaa kahtia. Siinä on jo vuod743205Antifasismi - mitä se on?
Se on äärivasemmistolaista anarkistista toimintaa joka käyttää fasisminvastaisuutta keppihevosena oikeuttaakseen toimint342588IL- KELA:n pääjohtaja, lääke- ja oikeustieteen tohtori Lasse Lehtonen sekavassa tilassa Brysselissä!
"Iltalehden tietojen mukaan Lehtosen käytös Brysselin lentokentällä on herättänyt huomiota, ja hänen olemuksensa on tulk2232363- 521708