Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Redmi Note 15 Pro+ 5G: autonomia monstre e display luminoso, ma il prezzo è alto
Redmi Note 15 Pro+ 5G: autonomia monstre e display luminoso, ma il prezzo è alto
Xiaomi ha portato sul mercato internazionale la nuova serie Redmi Note, che rappresenta spesso una delle migliori scelte per chi non vuole spendere molto. Il modello 15 Pro+ punta tutto su una batteria capiente e su un ampio display luminoso, sacrificando qualcosa in termini di potenza bruta e velocità di ricarica
HONOR Magic 8 Pro: ecco il primo TOP del 2026! La recensione
HONOR Magic 8 Pro: ecco il primo TOP del 2026! La recensione
HONOR ha finalmente lanciato il suo nuovo flagship: Magic 8 Pro. Lo abbiamo provato a fondo in queste settimane e ve lo raccontiamo nella nostra recensione completa. HONOR rimane fedele alle linee della versione precedente, aggiungendo però un nuovo tasto dedicato all'AI. Ma è al suo interno che c'è la vera rivoluzione grazie al nuovo Snapdragon 8 Elite Gen 5 e alla nuova MagicOS 10
Insta360 Link 2 Pro e 2C Pro: le webcam 4K che ti seguono, anche con gimbal integrata
Insta360 Link 2 Pro e 2C Pro: le webcam 4K che ti seguono, anche con gimbal integrata
Le webcam Insta360 Link 2 Pro e Link 2C Pro sono una proposta di fascia alta per chi cerca qualità 4K e tracciamento automatico del soggetto senza ricorrere a configurazioni complesse. Entrambi i modelli condividono sensore, ottiche e funzionalità audio avanzate, differenziandosi per il sistema di tracciamento: gimbal a due assi sul modello Link 2 Pro, soluzione digitale sul 2C Pro
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 17-07-2005, 17:22   #1
luxorl
Senior Member
 
L'Avatar di luxorl
 
Iscritto dal: Oct 2003
Città: Pisa/Cosenza
Messaggi: 1364
[Java] Devo imparare a creare metodi ricorsivi... da dove comincio?

Ciao,
premetto che sono a buon livello di programmazione orientata agli oggetti in java. Però quando si tratta di svolgere qualche esercizio dove bisogna implementare metodi ricorsivi vado nel pallone...

Sapete consigliarmi una guida on-line che mi possa aiutare?
O come mi consigliate di procedere per imparare bene la programmazione ricorsiva?

come sempre: Grazie
__________________
luxorl è offline   Rispondi citando il messaggio o parte di esso
Old 17-07-2005, 17:59   #2
franksisca
Senior Member
 
L'Avatar di franksisca
 
Iscritto dal: May 2005
Città: Roma
Messaggi: 7938
UNICAL


La ricorsione???
Guarda, io ho trovato di peggio, il BACKTRACKING!!!

prova sui libri della mokabyte, thinking in java e prova qualche manuale, tipo tecniche avanzate in java, altrimenti non saprei davvero dove reindirizzarti.CIAO
__________________
My gaming placement
franksisca è offline   Rispondi citando il messaggio o parte di esso
Old 17-07-2005, 18:01   #3
luxorl
Senior Member
 
L'Avatar di luxorl
 
Iscritto dal: Oct 2003
Città: Pisa/Cosenza
Messaggi: 1364
Ho qui con me l'Horstmann (Java 2 i Fondamenti) ma MI SEMBRA che non ci sia scritto niente a riguardo..
__________________
luxorl è offline   Rispondi citando il messaggio o parte di esso
Old 17-07-2005, 18:14   #4
luxorl
Senior Member
 
L'Avatar di luxorl
 
Iscritto dal: Oct 2003
Città: Pisa/Cosenza
Messaggi: 1364
Per esempio dovrei scrivere un metodo che accetta una stringa e restituisce un'altra stringa che è il contrario di quella accettata. Questo metodo deve essere ricorsivo.

Non è che potete darmi uno spunto su come risolvere questo problema?
__________________
luxorl è offline   Rispondi citando il messaggio o parte di esso
Old 17-07-2005, 18:21   #5
luxorl
Senior Member
 
L'Avatar di luxorl
 
Iscritto dal: Oct 2003
Città: Pisa/Cosenza
Messaggi: 1364
Io avevo pensato a qualcosa del genere:

Codice:
public class StringaRicorsiva{

	public static String reverse(String s){
		for(int i=0; i<s.length(); i++){
		String s2=s.charAt(s.length()-1)+s.substring(0, s.length()-2);
		reverse(s);
		}
		return s;
	}

	public static void main(String args[]){
		String s="speriamo";
		String c=reverse(s);
		System.out.println(c);
	}
}
ma non va
__________________
luxorl è offline   Rispondi citando il messaggio o parte di esso
Old 17-07-2005, 22:57   #6
jappilas
Senior Member
 
L'Avatar di jappilas
 
Iscritto dal: Apr 2003
Città: Genova
Messaggi: 4739
non va perchè messa in quel modo mi pare NON sia ricorsiva ...
la ricorsione si basa sul principio di induzione
applicato al caso della string reverse deriverebbe qualcosa del genere (che poi devi far sì che la funzione, implementi):

1)reverse (a) = a
2)reverse (a + str) = reverse (str) + a

1) è la funzione minima per la stringa di un solo carattere
con 2) reverse() invoca ripetutamente sè stessa finchè non si arriva al caso del singolo carattere: in questo è ricorsiva

nel tuo caso mi pare che il ciclo for nella funzione vanifichi di fatto la ricorsione, inoltre chiami la funzione con lo stesso parametro (s) che hai in ingresso...
ti basta fare un check iniziale (if s.length()>1) return s else ...
__________________
Jappilas is a character created by a friend for his own comic - I feel honored he allowed me to bear his name
Saber's true name belongs to myth - a Heroic Soul out of legends, fighting in our time to fullfill her only wish
Let her image remind of her story, and of the emotions that flew from my heart when i assisted to her Fate

Ultima modifica di jappilas : 17-07-2005 alle 23:09.
jappilas è offline   Rispondi citando il messaggio o parte di esso
Old 18-07-2005, 01:28   #7
^TiGeRShArK^
Senior Member
 
L'Avatar di ^TiGeRShArK^
 
Iscritto dal: Jul 2002
Città: Reggio Calabria -> London
Messaggi: 12112
odio la ricorsione!
__________________
^TiGeRShArK^ è offline   Rispondi citando il messaggio o parte di esso
Old 18-07-2005, 10:54   #8
luxorl
Senior Member
 
L'Avatar di luxorl
 
Iscritto dal: Oct 2003
Città: Pisa/Cosenza
Messaggi: 1364
Quote:
Originariamente inviato da jappilas
ti basta fare un check iniziale (if s.length()>1) return s else ...
(if s.length()< 1) return s else...

Comunque dopo una notte insonne ce l'ho fatta!!

Codice:
public class StringaRicorsiva{

	public static String reverse(String s){
		if(s.length()<1) return s;
		else{
		s=s.charAt(s.length()-1)+reverse(s.substring(0, s.length()-1));
		return s;
		}
	}


	public static void main(String args[]){
		String s="speriamo";
		String c=reverse(s);
		System.out.println(c);
	}
}
Una sola cosa:

se tolgo l'ultimo return s, il compilatore si arrabbia dicendo che manca il ritorno.. però logicamente prima o poi l'if sarà true quindi il ritorno ci sarà.. ma bisogna mettere comunque quel return s finale per accontentare il compilatore?

Senza non mi compila.
__________________
luxorl è offline   Rispondi citando il messaggio o parte di esso
Old 18-07-2005, 13:25   #9
pisto
 
Messaggi: n/a
Quote:
Originariamente inviato da luxorl
se tolgo l'ultimo return s, il compilatore si arrabbia dicendo che manca il ritorno.. però logicamente prima o poi l'if sarà true quindi il ritorno ci sarà.. ma bisogna mettere comunque quel return s finale per accontentare il compilatore?

Senza non mi compila.
mettiamocelo in testa che i copmputer sono stupidi!
però comunque è logico: metti che dopo il return ci sia ancora qualcosa da fare nel metodo: la jvm cosa fa, continua l'esecuzione del codice che ha richiamato il metodo (come dovrebbe fare, visto che ha ricevuto i dati in ritorno), o ciò che manca del metodo? visto che i due non sono due trhead, è alcuanto un problema...
  Rispondi citando il messaggio o parte di esso
Old 18-07-2005, 14:50   #10
51078
Senior Member
 
L'Avatar di 51078
 
Iscritto dal: Oct 2000
Messaggi: 637
Quote:
Originariamente inviato da luxorl

Una sola cosa:

se tolgo l'ultimo return s, il compilatore si arrabbia dicendo che manca il ritorno.. però logicamente prima o poi l'if sarà true quindi il ritorno ci sarà.. ma bisogna mettere comunque quel return s finale per accontentare il compilatore?

Senza non mi compila.

Succede perchè il return non può essere messo solo in una porzione di codice soggetta a condizioni, in quanto potrebbe non essere mai soddisfatta e quindi la funzione non ritornerebbe mai, questo a prescindere dal fatto che la condizione sia palesemente soddisfacibile, il compilatore non valuta questi fattori...




P.S. : Per la ricorsione quoto jappilas, devi sempre tenere presente che serve un caso base che determina la fine della ricorsione e il passo ricorsivo va fatto sempre in forma generale... Se vuoi far pratica usa un po PROLOG, poi diventi un mago della ricorsione...

Ultima modifica di 51078 : 18-07-2005 alle 14:53.
51078 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Redmi Note 15 Pro+ 5G: autonomia monstre e display luminoso, ma il prezzo è alto Redmi Note 15 Pro+ 5G: autonomia monstre e displ...
HONOR Magic 8 Pro: ecco il primo TOP del 2026! La recensione HONOR Magic 8 Pro: ecco il primo TOP del 2026! L...
Insta360 Link 2 Pro e 2C Pro: le webcam 4K che ti seguono, anche con gimbal integrata Insta360 Link 2 Pro e 2C Pro: le webcam 4K che t...
Motorola edge 70: lo smartphone ultrasottile che non rinuncia a batteria e concretezza Motorola edge 70: lo smartphone ultrasottile che...
Display, mini PC, periferiche e networking: le novità ASUS al CES 2026 Display, mini PC, periferiche e networking: le n...
I nuovi chip M5 Pro, Max e Ultra sono se...
Nuove livree, tocca a Haas "Toyota&...
Cambia la Dynamic Island? Con iPhone 18 ...
Xbox Cloud Gaming: in arrivo l'accesso s...
Snapdragon 8 Elite Gen 6 Pro potrebbe co...
L'IA è ovunque, ma alle aziende f...
La nave elettrica più grande mai ...
Spusu lancia il Wi-Fi Calling: come funz...
Questo robot impara a muovere le labbra ...
iPhone 17 annienta la concorrenza in Cin...
La nuova Xiaomi SU7 batte un record: 4.2...
È possibile copiare i qubit: dei ...
BYD alza ulteriormente l'asticella: batt...
Il nuovo razzo spaziale riutilizzabile c...
L'ex leader di Assassin's Creed porta Ub...
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: 09:08.


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