Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Polestar 3 Performance, test drive: comodità e potenza possono convivere
Polestar 3 Performance, test drive: comodità e potenza possono convivere
Abbiamo passato diversi giorni alla guida di Polestar 3, usata in tutti i contesti. Come auto di tutti i giorni è comodissima, ma se si libera tutta la potenza è stupefacente
Qualcomm Snapdragon X2 Elite: l'architettura del SoC per i notebook del 2026
Qualcomm Snapdragon X2 Elite: l'architettura del SoC per i notebook del 2026
In occasione del proprio Architecture Deep Dive 2025 Qualcomm ha mostrato in dettaglio l'architettura della propria prossima generazione di SoC destinati ai notebook Windows for ARM di prossima generazione. Snapdragon X2 Elite si candida, con sistemi in commercio nella prima metà del 2026, a portare nuove soluzioni nel mondo dei notebook sottili con grande autonomia
Recensione DJI Mini 5 Pro: il drone C0 ultra-leggero con sensore da 1 pollice
Recensione DJI Mini 5 Pro: il drone C0 ultra-leggero con sensore da 1 pollice
DJI Mini 5 Pro porta nella serie Mini il primo sensore CMOS da 1 pollice, unendo qualità d'immagine professionale alla portabilità estrema tipica di tutti i prodotti della famiglia. È un drone C0, quindi in un peso estremamente contenuto e che non richiede patentino, propone un gimbal rotabile a 225 gradi, rilevamento ostacoli anche notturno e autonomia fino a 36 minuti. Caratteristiche che rendono il nuovo drone un riferimento per creator e appassionati
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: 2780
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


Polestar 3 Performance, test drive: comodità e potenza possono convivere Polestar 3 Performance, test drive: comodit&agra...
Qualcomm Snapdragon X2 Elite: l'architettura del SoC per i notebook del 2026 Qualcomm Snapdragon X2 Elite: l'architettura del...
Recensione DJI Mini 5 Pro: il drone C0 ultra-leggero con sensore da 1 pollice Recensione DJI Mini 5 Pro: il drone C0 ultra-leg...
ASUS Expertbook PM3: il notebook robusto per le aziende ASUS Expertbook PM3: il notebook robusto per le ...
Test ride con Gowow Ori: elettrico e off-road vanno incredibilmente d'accordo Test ride con Gowow Ori: elettrico e off-road va...
Prezzo dell'ittrio fuori controllo: perc...
Grazie a VLT è stata misurata dir...
Blue Origin annuncia un aerofreno ripieg...
Blue Origin annuncia una nuova versione ...
LG UltraFine evo 6K: il primo monitor al...
DJI cambia direzione: investe in Elegoo ...
Black Friday Narwal 2025: risparmi da ca...
Phishing evoluto contro Apple ID: caso f...
Prestazioni in discesa nei giochi? NVIDI...
Addio ai banner dei cookie? L'UE spinge ...
Le offerte Black Friday per gli smartpho...
Il controllo qualità degli iPhone...
Qualcomm Snapdragon X Elite vola con il ...
A2RL Season 2: storia, innovazione e sor...
Core Ultra Series 3: Intel conferma l'ev...
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: 08:23.


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