Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Prova GeForce NOW upgrade Blackwell: il cloud gaming cambia per sempre
Prova GeForce NOW upgrade Blackwell: il cloud gaming cambia per sempre
L'abbonamento Ultimate di GeForce NOW ora comprende la nuova architettura Blackwell RTX con GPU RTX 5080 che garantisce prestazioni tre volte superiori alla precedente generazione. Non si tratta solo di velocità, ma di un'esperienza di gioco migliorata con nuove tecnologie di streaming e un catalogo giochi raddoppiato grazie alla funzione Install-to-Play
Ecovacs Deebot X11 Omnicyclone: niente più sacchetto per lo sporco
Ecovacs Deebot X11 Omnicyclone: niente più sacchetto per lo sporco
Deebot X11 Omnicyclone implementa tutte le ultime tecnologie Ecovacs per l'aspirazione dei pavimenti di casa e il loro lavaggio, con una novità: nella base di ricarica non c'è più il sacchetto di raccolta dello sporco, sostituito da un aspirapolvere ciclonico che accumula tutto in un contenitore rigido
Narwal Flow: con il mocio orizzontale lava i pavimenti al meglio
Narwal Flow: con il mocio orizzontale lava i pavimenti al meglio
Grazie ad un mocio rotante che viene costantemente bagnato e pulito, Narwal Flow assicura un completo e capillare lavaggio dei pavimenti di casa. La logica di intellignza artificiale integrata guida nella pulizia tra i diversi locali, sfruttando un motore di aspirazione molto potente e un sistema basculante per la spazzola molto efficace sui tappeti di casa
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 01-02-2007, 15:40   #1
alberto.frz
Member
 
L'Avatar di alberto.frz
 
Iscritto dal: Dec 2004
Città: Venezia
Messaggi: 192
[C] Funzioni Ricorsione

Ciao raga, qualcuno mi aiuta a scrivere questa funzione!?! Mi trovo un po' impacciato avendo due array...

ecco il testo:

Quote:
Definire una funzione ricorsiva int Inverse(char tab1[], tab2[], int dim) che, date due tabelle tab1, tab2 di caratteri della stessa dimensione dim, restituisce 1 se le tabelle contengono gli stessi elementi in ordine inverso, e restituisce 0 altrimenti.
__________________
alberto.frz è offline   Rispondi citando il messaggio o parte di esso
Old 01-02-2007, 16:08   #2
andbin
Senior Member
 
L'Avatar di andbin
 
Iscritto dal: Nov 2005
Città: TO
Messaggi: 5206
Quote:
Originariamente inviato da alberto.frz
ecco il testo:
Definire una funzione ricorsiva int Inverse(char tab1[], tab2[], int dim) che, date due tabelle tab1, tab2 di caratteri della stessa dimensione dim, restituisce 1 se le tabelle contengono gli stessi elementi in ordine inverso, e restituisce 0 altrimenti.
Uhm curioso .... questo esercizio l'ho già visto tale e quale, guarda caso, su un altro forum appena qualche settimana fa. Tra l'altro avevo pure postato la "mia" soluzione.

Stavolta però non posto la soluzione intera .... posso darti un piccolo indizio: quando chiami ricorsivamente la funzione devi passare, per uno dei 2 array (a te la scelta), l'indirizzo della seconda cella, in modo che nella funzione richiamata diventi "virtualmente" la prima cella. E devi anche passare una dimensione "più corta".
__________________
Andrea, SCJP 5 (91%) - SCWCD 5 (94%)
andbin è offline   Rispondi citando il messaggio o parte di esso
Old 01-02-2007, 16:15   #3
Furla
Senior Member
 
Iscritto dal: Feb 2004
Messaggi: 1454
se per "tabelle di caratteri" si intendono array di caratteri monodimensionali, l'alternativa alla soluzione di andbin è usare un argomento di default da porre uguale a zero, che aumenta ad ogni ricorsione fino a raggiungere dim/2...
Furla è offline   Rispondi citando il messaggio o parte di esso
Old 01-02-2007, 16:35   #4
alberto.frz
Member
 
L'Avatar di alberto.frz
 
Iscritto dal: Dec 2004
Città: Venezia
Messaggi: 192
vi mostro dove mi blocco io:

Codice:
 int Inverse (char tab1[], char tab2[], int dim) {
 
	if (dim==0) 
		return 1;
	if (tab1[dim-1]==tab2[cosa metto?])
				return Inverse(tab1,tab2,dim-1);
	
 return 0; 
 }
questo è quello che ho scritto fino ad ora, adesso provo a meditare sulle vostre dritte...ne sono cmq buone accette anche altre
__________________
alberto.frz è offline   Rispondi citando il messaggio o parte di esso
Old 01-02-2007, 16:44   #5
andbin
Senior Member
 
L'Avatar di andbin
 
Iscritto dal: Nov 2005
Città: TO
Messaggi: 5206
Quote:
Originariamente inviato da alberto.frz
Codice:
	if (tab1[dim-1]==tab2[cosa metto?])
				return Inverse(tab1,tab2,dim-1);
	
 return 0; 
 }
Se i 2 elementi sono uguali allora devi proseguire con la ricorsione.

E tieni a mente quanto ho detto sul passaggio di un puntatore alla cella successiva ...
__________________
Andrea, SCJP 5 (91%) - SCWCD 5 (94%)
andbin è offline   Rispondi citando il messaggio o parte di esso
Old 01-02-2007, 16:47   #6
alberto.frz
Member
 
L'Avatar di alberto.frz
 
Iscritto dal: Dec 2004
Città: Venezia
Messaggi: 192
eccolo!!!

è giusto? a me compila e funziona (sto usando xcode di osx)

Codice:
 int Inverse (char tab1[], char tab2[], int dim) {
 
	if (dim==0) 
		return 1;
	if (tab1[dim-1]==tab2[0])
			return Inverse(tab1,tab2+1,dim-1);
	
 return 0; 
 }
grazie, a pensarci bene non era proprio tanto difficile è che a volte mi sembra di avere due fette di mortadella sopra gli occhi!!!

era un esercizio di un vecchio esame di programmazione c...mi sto preparando per l'esame...

grazie a tutti
__________________
alberto.frz è offline   Rispondi citando il messaggio o parte di esso
Old 01-02-2007, 16:58   #7
andbin
Senior Member
 
L'Avatar di andbin
 
Iscritto dal: Nov 2005
Città: TO
Messaggi: 5206
Quote:
Originariamente inviato da alberto.frz
eccolo!!!

è giusto? a me compila e funziona (sto usando xcode di osx)
È ok ... ben fatto!
__________________
Andrea, SCJP 5 (91%) - SCWCD 5 (94%)
andbin è offline   Rispondi citando il messaggio o parte di esso
Old 01-02-2007, 17:03   #8
alberto.frz
Member
 
L'Avatar di alberto.frz
 
Iscritto dal: Dec 2004
Città: Venezia
Messaggi: 192
Quote:
Originariamente inviato da andbin
È ok ... ben fatto!
grazie a voi!!!

andbin devo farti i complimenti xkè leggendo qua e la nel forum ho visto che le sai proprio tutte!!!
__________________
alberto.frz è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Prova GeForce NOW upgrade Blackwell: il cloud gaming cambia per sempre Prova GeForce NOW upgrade Blackwell: il cloud ga...
Ecovacs Deebot X11 Omnicyclone: niente più sacchetto per lo sporco Ecovacs Deebot X11 Omnicyclone: niente più...
Narwal Flow: con il mocio orizzontale lava i pavimenti al meglio Narwal Flow: con il mocio orizzontale lava i pav...
Panasonic 55Z95BEG cala gli assi: pannello Tandem e audio senza compromessi Panasonic 55Z95BEG cala gli assi: pannello Tande...
HONOR Magic V5: il pieghevole ultra sottile e completo! La recensione HONOR Magic V5: il pieghevole ultra sottile e co...
Cos’è RSL, il nuovo standard che ...
Nissan Micra EV: da 29.500 a oltre 36.00...
Processo Microsoft-ValueLicensing: cosa ...
L'edizione limitata più ambita da...
Lo sviluppatore di MSI Afterburner svela...
Quando l'AI diventa maestro: così...
Sony WH-1000XM6 già scontate su A...
NVIDIA chiede più velocità...
Windows 11 in soli 2,8 GB: con questo sc...
Panico in casa HYTE: ritirato dal mercat...
OPPO Reno14, debutto tra rooftoop esclus...
3DAIQ, il progetto di Concept Reply e TE...
Il parlamento francese contro TikTok: '&...
Apple Watch SE 2ª gen. Cellular a soli 2...
MotoE sospesa dopo il 2025: fine tempora...
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: 20:34.


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