Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Ecovacs DEEBOT T90 PRO OMNI: ora il rullo di lavaggio è ampio
Ecovacs DEEBOT T90 PRO OMNI: ora il rullo di lavaggio è ampio
DEEBOT T90 PRO OMNI abbina un sistema di aspirazione basato su tecnologia BLAST ad un rullo di lavaggio dei pavimenti dalla larghezza elevata, capace di trattare al meglio le superfici di casa minimizzando i tempi di lavoro. Un robot completo che riesce anche ad essere sottile e garantire automazione ed efficienza nelle operazioni di pulizia di casa
Recensione Samsung Galaxy S26 Ultra: finalmente qualcosa di nuovo
Recensione Samsung Galaxy S26 Ultra: finalmente qualcosa di nuovo
Per diversi giorni il Galaxy S26 Ultra di Samsung è stato il nostro compagno di vita. Oltre alle conferme del colosso coreano come la qualità del display e una suite AI senza rivali, arriva il Privacy Display, un unicum nel mondo smartphone. Ci sono ancora alcuni gap che non sono riusciti a colmare lato batteria e fotocamera, seppur con alcuni miglioramenti.
Diablo II Resurrected: il nuovo DLC Reign of the Warlock
Diablo II Resurrected: il nuovo DLC Reign of the Warlock
Abbiamo provato per voi il nuovo DLC lanciato a sorpresa da Blizzard per Diablo II: Resurrected e quella che segue è una disamina dei nuovi contenuti che abbiamo avuto modo di sperimentare nel corso delle nostre sessioni di gioco, con particolare riguardo per la nuova classe dello Stregone
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 09-01-2011, 21:52   #1
fenzo
Member
 
Iscritto dal: Jun 2004
Messaggi: 56
[c]segmentation error con funzione ricorsiva

ciao a tutti
sto scrivendo un programma che ha una funzione ricorsiva.
Per essere precisi devo effettuare 8 chiamate ricorsive.
Quando eseguo il file (da terminale di Ubuntu) mi compare l'errore "segmentation error".
dato che sono ai primi passi col c, qualcuno con una conoscenza maggiore potrebbe dirmi dove ho sbagliato?
questo è il codice
Codice:
void sierpinskiCarpet(int n, char M[n][n], int r0, int c0, int k){
int i,cf,rf,b,j,h,l,m,cr;
int cs=1;
int z=n;
for (i=1;i<=k;i++)
	cs*=3;
rf=r0+cs-1;
cf=c0+cs-1;
b=cs/3;
cr=2*b;
if (rf>z || cf>z) return;
if (r0>z || c0>z) return;
for(j=0;j<=rf;j++)
	for(h=0;h<=cf;h++){
		if(j>=b+r0 && j<cr+r0 && h>=b+c0 && h<cr+c0)
			M[j][h]=48;
		else M[j][h]=49;    }
k--;
sierpinskiCarpet(z,M,r0,c0,k);
sierpinskiCarpet(z,M,r0,b,k);
sierpinskiCarpet(z,M,r0,cr,k);
sierpinskiCarpet(z,M,b,c0,k);
sierpinskiCarpet(z,M,b,cr,k);
sierpinskiCarpet(z,M,cr,c0,k);
sierpinskiCarpet(z,M,cr,b,k);
sierpinskiCarpet(z,M,cr,cr,k);
if (k<=1) return;}
grazie
__________________
I don't think you trust
In, my, self righteous suicide
I, cry, when angels deserve to die.
fenzo è offline   Rispondi citando il messaggio o parte di esso
Old 09-01-2011, 22:09   #2
fenzo
Member
 
Iscritto dal: Jun 2004
Messaggi: 56
pensavo di aver commesso un errore proprio nel codice durante le varie chiamate
quale debugger consigli per ubuntu?
__________________
I don't think you trust
In, my, self righteous suicide
I, cry, when angels deserve to die.
fenzo è offline   Rispondi citando il messaggio o parte di esso
Old 09-01-2011, 22:19   #3
wingman87
Senior Member
 
Iscritto dal: Nov 2005
Messaggi: 2788
Probabilmente la ricorsione non termina mai.
Poi l'if finale a cosa serve? Tanto la funzione termina lì lo stesso... Non è che quell'istruzione doveva trovarsi prima tra le condizioni di terminazione?
wingman87 è offline   Rispondi citando il messaggio o parte di esso
Old 09-01-2011, 22:36   #4
fenzo
Member
 
Iscritto dal: Jun 2004
Messaggi: 56
l'if finale dovrebbe essere la condizione di terminazione in teoria...
__________________
I don't think you trust
In, my, self righteous suicide
I, cry, when angels deserve to die.
fenzo è offline   Rispondi citando il messaggio o parte di esso
Old 09-01-2011, 22:56   #5
tuccio`
Senior Member
 
Iscritto dal: Apr 2010
Città: Frosinone
Messaggi: 416
mi sfugge un po' la logica del programma, un po' perché è incasinato e un po' perché non mi va di leggerlo più attentamente

però ti butto lì una domanda: potrebbe essere che a causa di quella condizione alla fine della chiamata (e in particolare dopo il for) accedi a valori fuori dalla matrice nel ciclo? anche questa è una causa di segfault

in genere nelle funzioni ricorsive, specialmente quelle semplici, le condizioni di uscita sono all'inizio
tuccio` è offline   Rispondi citando il messaggio o parte di esso
Old 10-01-2011, 02:10   #6
fenzo
Member
 
Iscritto dal: Jun 2004
Messaggi: 56
Quote:
Originariamente inviato da tuccio` Guarda i messaggi
mi sfugge un po' la logica del programma, un po' perché è incasinato e un po' perché non mi va di leggerlo più attentamente
la funzione deve "disegnare" nella sottomatrice con indici superiori sinistri r0 e c0 della matrice M il tappeto di Sierpinski di ordine k.
Lo devo fare per il corso di C che faccio all'università (quindi serve solo per vedere se hai capito certi argomenti).

il problema è nella ricorsione perchè ho provato a eliminare le chiamate ricorsive e il programma funziona perfettamente (però fa solo il primo passaggio). Se aggiungo le chiamate ricorsive mi compare quell'errore. Inizialmente avevo messo una sola chiamata ricorsiva all'interno di due for che cambiavano i due indici c0 e r0. Pensavo che fosse quello il problema perciò ho messo tutte e otto le chiamate ma è lo stesso. Però m'hai fatto venì il dubbio:
dato che la condizione di uscita sta alla fine, come arriva alla prima chiamata continua all''infinito. Domani metto la condizione prima delle chiamate; forse funziona.
__________________
I don't think you trust
In, my, self righteous suicide
I, cry, when angels deserve to die.
fenzo è offline   Rispondi citando il messaggio o parte di esso
Old 10-01-2011, 18:31   #7
Ufo13
Senior Member
 
L'Avatar di Ufo13
 
Iscritto dal: Nov 2005
Messaggi: 1545
Consiglio: scrivilo bene il codice altrimenti la gente manco ha voglia di leggerlo.
Ufo13 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Ecovacs DEEBOT T90 PRO OMNI: ora il rullo di lavaggio è ampio Ecovacs DEEBOT T90 PRO OMNI: ora il rullo di lav...
Recensione Samsung Galaxy S26 Ultra: finalmente qualcosa di nuovo Recensione Samsung Galaxy S26 Ultra: finalmente ...
Diablo II Resurrected: il nuovo DLC Reign of the Warlock Diablo II Resurrected: il nuovo DLC Reign of the...
Deep Tech Revolution: così Area Science Park apre i laboratori alle startup Deep Tech Revolution: così Area Science P...
HP OMEN MAX 16 con RTX 5080: potenza da desktop replacement a prezzo competitivo HP OMEN MAX 16 con RTX 5080: potenza da desktop ...
NVIDIA sta fornendo circa il 20% in meno...
L'interfaccia Liquid Glass di Apple &egr...
Maserati diventa di Xiaomi? Le indiscrez...
Pragmata supera i 2 milioni di wishlist ...
Ultime ore per le Offerte di Primavera: ...
Bitcoin, 20 milioni di BTC minati: l'ind...
Microsoft ridimensiona Copilot su Window...
Ultime ore per le Offerte di Primavera: ...
FRITZ!Box 6825 4G: il router LTE che fun...
Abbiamo scoperto la gamma Ego Power+ 202...
Il telescopio spaziale James Webb ha per...
Sony WH-1000XM5 in forte sconto: le cuff...
In Europa i videogiochi con loot box avr...
Ultimo giorno di Offerte di Primavera: e...
La crisi delle memorie potrebbe continua...
Chromium
GPU-Z
OCCT
LibreOffice Portable
Opera One Portable
Opera One 106
CCleaner Portable
CCleaner Standard
Cpu-Z
Driver NVIDIA GeForce 546.65 WHQL
SmartFTP
Trillian
Google Chrome Portable
Google Chrome 120
VirtualBox
Tutti gli articoli Tutte le news Tutti i download

Strumenti

Regole
Non Puoi aprire nuove discussioni
Non Puoi rispondere ai messaggi
Non Puoi allegare file
Non Puoi modificare i tuoi messaggi

Il codice vB è On
Le Faccine sono On
Il codice [IMG] è On
Il codice HTML è Off
Vai al Forum


Tutti gli orari sono GMT +1. Ora sono le: 13:03.


Powered by vBulletin® Version 3.6.4
Copyright ©2000 - 2026, Jelsoft Enterprises Ltd.
Served by www3v