Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Google Pixel 10 è compatto e ha uno zoom 5x a 899€: basta per essere un best-buy?
Google Pixel 10 è compatto e ha uno zoom 5x a 899€: basta per essere un best-buy?
Google Pixel 10 è uno smartphone che unisce una fotocamera molto più versatile rispetto al passato grazie allo zoom ottico 5x, il supporto magnetico Pixelsnap e il nuovo chip Tensor G5. Il dispositivo porta Android 16 e funzionalità AI avanzate come Camera Coach, mantenendo il design caratteristico della serie Pixel con miglioramenti nelle prestazioni e nell'autonomia. In Italia, però, mancano diverse feature peculiari basate sull'AI.
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
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 03-07-2011, 22:16   #1
x3d0
Member
 
Iscritto dal: Jun 2008
Messaggi: 159
[JAVA] Ricerca tra i nodi di un albero binario

Premetto che non posso utilizzare Java Collection o altri framework

Questa è la classe che definisce il nodo

Codice PHP:
public class NodoBin {
    
String info;
    
NodoBin sin;
    
NodoBin des;

    public 
NodoBin(String iNodoBin sNodoBin d) {
        
this.info i;
        
this.sin s;
        
this.des d;
    }


Questo è il codice della creazione di una lista di nodi dell'albero

Codice PHP:
String s1 "Giovanni";
        
String s2 "Maria";
        
String s3 "Marco";
        
String s4 "Sergio";
        
String s5 "Giulia";
        
String s6 "Marta";

        
// Creazione nodi
        
NodoBin n1 = new NodoBin(s1nullnull);
        
NodoBin n2 = new NodoBin(s2nullnull);
        
NodoBin n3 = new NodoBin(s3nullnull);
        
NodoBin n4 = new NodoBin(s4nullnull);
        
NodoBin n5 = new NodoBin(s5nullnull);
        
NodoBin n6 = new NodoBin(s6nullnull);

        
// Creazione albero
        
n1.sin n2;
        
n1.des n3;
        
n2.sin n4;
        
n2.des n5;
        
n3.des n6
Devo scrivere un metodo "cerca", che esegue la ricerca di un elemento in un albero binario di oggetti della classe NodoBin.
In particolare, il metodo "cerca" riceve in ingresso il riferimento alla radice dell'albero e una stringa
x. Qualora il campo info di un nodo dell'albero abbia valore uguale a quello della stringa x, il metodo restituisce il riferimento a tale nodo, altrimenti esso restituisce null (per semplicità tutti i nodi dell'albero abbiano valori di versi del campo info).


Ho iniziato a scrivere il metodo "cerca", ma non riesco a capire come renderlo ricorsivo per tutti i nodi
Codice PHP:
public static NodoBin cerca(NodoBin rString s)
    {
        if(
== null)
        {
            return 
null;
        }
        
        if(
r.info.equals(s))
        {
            return 
r;
        }else{
            return 
null;
        }
        
    } 
Il problema è che in questo modo non esamino nè r.sin, nè r.des, e di conseguenza tutti i nodi figli!
x3d0 è offline   Rispondi citando il messaggio o parte di esso
Old 03-07-2011, 22:56   #2
Mixmar
Senior Member
 
L'Avatar di Mixmar
 
Iscritto dal: Feb 2002
Città: Trento
Messaggi: 962
Nel secondo "else", puoi ispezionare sia il ramo sinistro, che quello destro, semplicemente invocando di nuovo la funzione su "r.sin" e "r.des". Poi ritorni null se entrambi i risultati sono null, altrimenti ritorna quello che non è null.
__________________
"Et Eärallo Endorenna utúlien. Sinome maruvan ar Hildinyar tenn' Ambar-metta!" -- Aragorn Elessar, Heir of Isildur
Mixmar -- OpenSuSE 11.1 on AMD 64 3000+ on DFI LanParty nF4-D | GeForce 6600 GT + Thermaltake Schooner on Samsung 710N
Storage -- ( 2 x Hitachi Deskstar 80 Gb + 1 x Hitachi 250 Gb ) = 1 RAID 5 + 1 Storage space LaCie Ethernet Disk Mini 250 Gb | HP - DV2150 EL MILAN CLAN
Mixmar è offline   Rispondi citando il messaggio o parte di esso
Old 03-07-2011, 22:58   #3
x3d0
Member
 
Iscritto dal: Jun 2008
Messaggi: 159
Quote:
Originariamente inviato da Mixmar Guarda i messaggi
Nel secondo "else", puoi ispezionare sia il ramo sinistro, che quello destro, semplicemente invocando di nuovo la funzione su "r.sin" e "r.des". Poi ritorni null se entrambi i risultati sono null, altrimenti ritorna quello che non è null.
Ok, e se volessi ripeterlo ricorsivamente su tutti i sotto-nodi della radice "r".
Potresti scrivermi concretamente il pezzo di codice?
x3d0 è offline   Rispondi citando il messaggio o parte di esso
Old 04-07-2011, 07:31   #4
clockover
Senior Member
 
L'Avatar di clockover
 
Iscritto dal: Oct 2004
Messaggi: 1945
Procedi in questo modo
1) se il nodo parametro == null ritorni null
2) chiave == stringa ritorni il nodo parametro
3) se la chiamata ricorsiva al nodo sinistro ha come risultato != null ritorni il risultato
4) se la chiamata ricorsiva precedente ha avuto risultato null effettui la chiamata ricorsiva al nodo destro. Se la chiamata ha come risultato un valore != null ritorni il risultato altrimenti ritorni null

Dove nodo parametro è nella tua funzione postata prima NodoBin r
clockover è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Google Pixel 10 è compatto e ha uno zoom 5x a 899€: basta per essere un best-buy? Google Pixel 10 è compatto e ha uno zoom ...
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...
Nuovo test di accensione dei motori per ...
Novità dalle analisi dell'asteroi...
La PS6 sarà più potente del previsto: ec...
Sony svela Xperia 10 VII: è il nu...
Amazon Weekend da urlo: iPhone 16 a prez...
Spotify diffida ReVanced: chiesta la rim...
Spazzolini elettrici Oral-B iO in super ...
Samsung Galaxy Watch8 Classic e Watch7 a...
Blue Origin prosegue lo sviluppo di Blue...
Roborock Saros 10 e 10R dominano il merc...
Apple scatenata su Amazon: tutti gli sco...
Canon EOS C50 è la nuova videocam...
ASUS ProArt P16 arriva in Italia: la wor...
Fujifilm presenta l'obiettivo FUJINON GF...
Il grafene ha appena 'infranto' una legg...
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: 19:15.


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