Torna indietro   Hardware Upgrade Forum > Software > Programmazione

NL-LC1 è il primo dissipatore a liquido AIO di Noctua: silenzio è la parola d'ordine
NL-LC1 è il primo dissipatore a liquido AIO di Noctua: silenzio è la parola d'ordine
Dopo anni di attesa e una lunga fase di sviluppo, Noctua entra nel mercato dei dissipatori a liquido AIO con la nuova serie NL-LC1. Forte dell'esperienza maturata nel raffreddamento ad aria, l'azienda austriaca promette di portare la propria filosofia fatta di qualità costruttiva, attenzione ai dettagli e silenziosità anche in questo segmento. Abbiamo provato il nuovo sistema per scoprire se riesce a distinguersi in un mercato ormai molto competitivo.
Boox Go 10.3 (Gen II) Lumi: il tablet e-ink con Android 15 e penna, dal prezzo super
Boox Go 10.3 (Gen II) Lumi: il tablet e-ink con Android 15 e penna, dal prezzo super
Arrivato sul mercato italiano a fine marzo, la serie Boox Go 10.3 (Gen II) offre Android 15, penna da 4096 livelli e retroilluminazione opzionale (nel modello da noi provato, Lumi, presente). La serie si compone di due tablet ePaper che fanno da e-reader, blocco note digitale e persino browser, tutto a un prezzo che fa dimenticare i prodotti di brand più blasonati
Gigabyte MO32U24 OLED: il 4K a 240Hz su un pannello OLED ideale per il gaming
Gigabyte MO32U24 OLED: il 4K a 240Hz su un pannello OLED ideale per il gaming
Pannello QD-OLED da 32 pollici con risoluzione 4K, frequenza di aggiornamento a 240Hz e tempi di risposta rapidissimi: il Gigabyte MO32U24 evolve il progetto del suo predecessore MO32U e alza ulteriormente l'asticella delle prestazioni. È ancora una volta un monitor indirizzato ai giocatori più esigenti
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 07-06-2013, 21:57   #1
Katastrophe1602
Junior Member
 
Iscritto dal: Jun 2013
Messaggi: 3
[Java] metodi ricorsivi

ho un albero binario:
class Albero {
Albero left, right;
int val;

Albero(int i, Albero a, Albero b){
left=a;
right=b;
val=i;
}
}

Esempio inizializzazione:
Albero x=new Albero(3, new Albero(6,null,null),new Albero(2, null, new Albero(3,null,null)));
Non riesco a capire come fare un metodo ricorsivo per visualizzare tutti gli elementi a distanza n dalla radice
Katastrophe1602 è offline   Rispondi citando il messaggio o parte di esso
Old 08-06-2013, 08:40   #2
ingframin
Senior Member
 
L'Avatar di ingframin
 
Iscritto dal: Apr 2010
Città: Leuven
Messaggi: 667
Quote:
Originariamente inviato da Katastrophe1602 Guarda i messaggi
ho un albero binario:
class Albero {
Albero left, right;
int val;

Albero(int i, Albero a, Albero b){
left=a;
right=b;
val=i;
}
}

Esempio inizializzazione:
Albero x=new Albero(3, new Albero(6,null,null),new Albero(2, null, new Albero(3,null,null)));
Non riesco a capire come fare un metodo ricorsivo per visualizzare tutti gli elementi a distanza n dalla radice
Codice:
public class Node {
	Node left;
	Node right;
	int val;
	
	public Node(int value) {
		this.val = value;
	}

	public void append(int val){
		if(val>this.val){
			if(this.right!= null){
				this.right.append(val);
			}
			else{
				this.right = new Node(val);
			}
		}//val>this.val
		if(val<this.val){
			if(this.left!=null){
				this.left.append(val);
			}
			else{
				this.left = new Node(val);
			}
		}//val<this.val
				
	}//append
	
	public void print(){
		System.out.println(this.val);
		if(this.right != null){
			System.out.print("right= ");
			this.right.print();
		}
		if(this.left != null){
			System.out.print("left= ");
			this.left.print();
		}
		
		
	}//print
	
	public void print(int level){
		
		if (level>0) {
			System.out.println(this.val);
			if (this.right != null) {
				System.out.print("right= ");
				this.right.print(level-1);
			}
			if (this.left != null) {
				System.out.print("left= ");
				this.left.print(level-1);
			}
		}
		
		
	}//print

	
	public static void main(String[]args){
		Node a = new Node(5);
		for(int i= 0; i<10;i++){
			a.append(i);
			a.append(i-5);
		}
		
		a.print();
		a.print(2);
		
	}
}
Tié, magnace il pane :P
A parte gli scherzi, se non ti è chiaro te lo spiego con più dettagli
__________________
L'elettronica digitale non esiste, è solo elettrotecnica con interruttori piccoli!
ingframin è offline   Rispondi citando il messaggio o parte di esso
Old 08-06-2013, 13:06   #3
clockover
Senior Member
 
L'Avatar di clockover
 
Iscritto dal: Oct 2004
Messaggi: 1945
Io l'avrei fatto così, non l'ho provato ma più o meno dovrebbe essere così
Codice:
public void print(distanza, nodo){
    if nodo == null
        return
    print(0, distanza, nodo);
}
private void print(current, distanza, nodo){
    if current == distanza
        stampa elemento
    else
        if nodo.left != null
            print(current + 1, distanza, nodo.left)
        if nodo.right != null
            print(current + 1, distanza, nodo.right)
}
1) effettui un controllo sul nodo passato come parametro
2) richiami il metodo print con la distanza corrente, quella richiesta e il nodo
3) se la distanza corrente è uguale a quella richiesta stampa
4) altrimenti, dopo aver verificato la presenza del nodo sinistro, effettua una chiamata ricorsiva a sinistra, incrementando il contatore della distanza corrente
5) idem com sopra per il destro

@ingframin
ma in quel modo non stampi tutti gli elementi che si trovano a meno di quella distanza?
clockover è offline   Rispondi citando il messaggio o parte di esso
Old 08-06-2013, 15:41   #4
ingframin
Senior Member
 
L'Avatar di ingframin
 
Iscritto dal: Apr 2010
Città: Leuven
Messaggi: 667
Io ho inteso la distanza come il numero di step a partire dal nodo radice.
In effetti credo di avere inteso male la domanda, nel senso che ho capito:
"stampare tutti i nodi fino al raggiungimento della distanza".
Per stampare solo quelli a distanza n basta usare il mio procedimento passando come parametro n+1 e poi usare print solo quando il contatore arriva a 0.
Mi sa che ho preso una piccola cantonata stamattina
__________________
L'elettronica digitale non esiste, è solo elettrotecnica con interruttori piccoli!
ingframin è offline   Rispondi citando il messaggio o parte di esso
Old 08-06-2013, 15:59   #5
Katastrophe1602
Junior Member
 
Iscritto dal: Jun 2013
Messaggi: 3
whoa, che rapidità : P
grazie delle risposte, riguardo la prima ci devo ragionare ancora su.
la seconda l'ho sistemata per farla funzionare : P

public void print(int distanza, Albero a){
if (a!= null)
print(1, distanza, a);
else System.out.println("Albero vuoto");
}
private void print(int current,int distanza, Albero nodo){
if(nodo!=null)
if (current == distanza)
System.out.println(nodo.val);
else{
if (nodo.left != null)
print(current + 1, distanza, nodo.left);
if (nodo.right != null)
print(current + 1, distanza, nodo.right);
}
}
Katastrophe1602 è offline   Rispondi citando il messaggio o parte di esso
Old 08-06-2013, 16:28   #6
clockover
Senior Member
 
L'Avatar di clockover
 
Iscritto dal: Oct 2004
Messaggi: 1945
Quote:
Originariamente inviato da Katastrophe1602 Guarda i messaggi
whoa, che rapidità : P
grazie delle risposte, riguardo la prima ci devo ragionare ancora su.
la seconda l'ho sistemata per farla funzionare : P

public void print(int distanza, Albero a){
if (a!= null)
print(1, distanza, a);
else System.out.println("Albero vuoto");
}
private void print(int current,int distanza, Albero nodo){
if(nodo!=null)
if (current == distanza)
System.out.println(nodo.val);
else{
if (nodo.left != null)
print(current + 1, distanza, nodo.left);
if (nodo.right != null)
print(current + 1, distanza, nodo.right);
}
}
Si ma fammi il piacere di indentare il codice. Come vedi le due risposte che hai ricevuto con il codice sono ordinate. Aiutaci ad aiutarti. Ci sono delle discussioni su questo forum che personalmente non prendo neanche in considerazione solo perchè il codice non è indentato.
clockover è offline   Rispondi citando il messaggio o parte di esso
Old 08-06-2013, 16:49   #7
Katastrophe1602
Junior Member
 
Iscritto dal: Jun 2013
Messaggi: 3
si scusate, nn trovavo come inserire il codice : P ho notato ora che toglie i tab inserendolo senza.
Codice:
public void print(int distanza, Albero a){
    if (a!= null)
        print(1, distanza, a);
    else System.out.println("Albero vuoto");
	}
private void print(int current,int distanza, Albero nodo){
	if(nodo!=null)
	    if (current == distanza)
	        System.out.println(nodo.val);
	    else{
	        if (nodo.left != null)	        	
	            print(current + 1, distanza, nodo.left);
	        if (nodo.right != null)
	            print(current + 1, distanza, nodo.right);
		}
}
comunque è funzionante, con questo ho finito gli esercizi delativi all'argomento, ora passerò alla gestione di liste.
grazie mille penso che il topic sia risolto
Katastrophe1602 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


NL-LC1 è il primo dissipatore a liquido AIO di Noctua: silenzio è la parola d'ordine NL-LC1 è il primo dissipatore a liquido A...
Boox Go 10.3 (Gen II) Lumi: il tablet e-ink con Android 15 e penna, dal prezzo super Boox Go 10.3 (Gen II) Lumi: il tablet e-ink con ...
Gigabyte MO32U24 OLED: il 4K a 240Hz su un pannello OLED ideale per il gaming Gigabyte MO32U24 OLED: il 4K a 240Hz su un panne...
Recensione realme 16 5G: lo smartphone con Selfie Mirror ha una batteria da 6550mAh Recensione realme 16 5G: lo smartphone con Selfi...
Come rispettare tutte le nuove regole per i monopattini elettrici? La guida per non rischiare sanzioni Come rispettare tutte le nuove regole per i mono...
Toyota presenta il primo pickup elettric...
Prime Day anticipato, tutti gli smartpho...
Dyson V10 Konical: il primo aspirapolver...
FSR 4.1 su Radeon 6000, AMD spiega perch...
Hisense svela la gamma TV 2026: RGB Mini...
Narwal lancia gli sconti Prime Day 2026:...
SpaceX ha comprato Cursor: accordo da 60...
Commodore Callback 8020 è il tele...
roborock F25 Ultra a 585€ con Prime: vap...
Apple Watch SE 3 a 219€ e Series 11 a 32...
La lampadina diventa una "biblioteca dig...
Philips Airfryer Serie 1000 con cestello...
Dashcam 3 canali 4K con STARVIS 2 e parc...
Il finto colloquio su LinkedIn nasconde ...
Prime Day in anticipo - giorno 2: ecco l...
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: 14:34.


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