Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Hisense A85N: il ritorno all’OLED è convincente e alla portata di tutti
Hisense A85N: il ritorno all’OLED è convincente e alla portata di tutti
Dopo alcuni anni di assenza dai cataloghi dei suoi televisori, Hisense riporta sul mercato una proposta OLED che punta tutto sul rapporto qualità prezzo. Hisense 55A85N è un televisore completo e versatile che riesce a convincere anche senza raggiungere le vette di televisori di altra fascia (e altro prezzo)
Recensione Borderlands 4, tra divertimento e problemi tecnici
Recensione Borderlands 4, tra divertimento e problemi tecnici
Gearbox Software rilancia la saga con Borderlands 4, ora disponibile su PS5, Xbox Series X|S e PC. Tra le novità spiccano nuove abilità di movimento, un pianeta inedito da esplorare e una campagna che lascia al giocatore piena libertà di approccio
TCL NXTPAPER 60 Ultra: lo smartphone che trasforma la lettura da digitale a naturale
TCL NXTPAPER 60 Ultra: lo smartphone che trasforma la lettura da digitale a naturale
NXTPAPER 60 Ultra è il primo smartphone con tecnologia NXTPAPER 4.0 per il display, un ampio IPS da 7,2 pollici. Con finitura anti-riflesso, processore MediaTek Dimensity 7400, fotocamera periscopica e modalità Max Ink per il detox digitale, NXTPAPER 60 Ultra punta a essere il riferimento tra gli smartphone pensati per il benessere degli occhi.
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 29-06-2008, 15:19   #1
wizard1993
Senior Member
 
L'Avatar di wizard1993
 
Iscritto dal: Apr 2006
Messaggi: 22462
[java] problema con albero di ricerca binario

sto implementando un classe che gestica un albero di ricerca binario
e ho scritto questo codice
Codice:
public class tree {
    private node root=new node();
    private void insert(node root,int data){
             if(root==null){
                  root=new node();
                  root.data=data;
                  System.out.println(data);//testcase
            }
            else{
                if(root.data==null){
                    root.data=data;
                  
                }
                else{
                  
                    if(data>root.data){
                        this.insert(root.destra,data);
                        System.out.print("a"); //testcase
                    }
                    else{
                        this.insert(root.sinistra, data);
                        System.out.print("a"); //testcase
                    }
                }
            }
    }
    public void insert(int data){
         this.insert(root, data);
    }
    
    public void get(){
        this.get(root);
    }
    private void get(node root){
        
        if(root==null)return;
        else{
            this.get(root.sinistra);
            System.out.println(root);
            this.get(root.destra);
        }
    }
}
class node{
    node sinistra,destra;
    Integer data;
    @Override
    public String toString(){
        return data.toString();
    }
}
il mio problema è che quando vado a chiamare il metodo get questo non visualizza nulla; io purtroppo non ci vedo alcun errore; potete per favore darci un occhio?
uso netbeans 6.1
__________________
amd a64x2 4400+ sk939;asus a8n-sli; 2x1gb ddr400; x850 crossfire; 2 x western digital abys 320gb|| asus g1
Se striscia fulmina, se svolazza l'ammazza
wizard1993 è offline   Rispondi citando il messaggio o parte di esso
Old 29-06-2008, 15:41   #2
wingman87
Senior Member
 
Iscritto dal: Nov 2005
Messaggi: 2775
Ciao, io vedo un errore nella insert, però in teoria la get dovrebbe stamparti almeno il valore della radice (o NULL se non ci hai messo niente).
L'errore è qui:
Codice:
else{
   if(data>root.data){
      this.insert(root.destra,data);
      System.out.print("a"); //testcase
   }else{
      this.insert(root.sinistra, data);
      System.out.print("a"); //testcase
   }
}
Quando richiami this.insert passi un riferimento a root.destra o a root.sinistra, solo che se questi non sono stati inizializzati stai passando un riferimento a NULL, quindi i nodi che creerai in quella invocazione andranno persi. Puoi risolvere così:
Codice:
else{
   if(data>root.data){
      if(root.destra==NULL)
         root.destra=new node();
      this.insert(root.destra,data);
      System.out.print("a"); //testcase
   }else{
      ...
wingman87 è offline   Rispondi citando il messaggio o parte di esso
Old 29-06-2008, 15:57   #3
wizard1993
Senior Member
 
L'Avatar di wizard1993
 
Iscritto dal: Apr 2006
Messaggi: 22462
grazie infinite; ho risolto;
adesso la classe fa quel che deve fare
comunque prima il get non stampava nemmeno null; comunque ora che ho risolto credo che il problema sia risoltp
__________________
amd a64x2 4400+ sk939;asus a8n-sli; 2x1gb ddr400; x850 crossfire; 2 x western digital abys 320gb|| asus g1
Se striscia fulmina, se svolazza l'ammazza
wizard1993 è offline   Rispondi citando il messaggio o parte di esso
Old 29-06-2008, 20:21   #4
feboss
Senior Member
 
L'Avatar di feboss
 
Iscritto dal: Sep 2006
Città: Catania
Messaggi: 742
L'inserimento così non va meglio?
Codice:
public void insert(node root, int data)
{
	if (root == null)
            root = new Node(data)
        else if (data > root.data)
        {
        	this.insert(root.destra, data);
                System.out.print("a"); //testcase
        }
        else if (data < root.data)
        {
        	this.insert(root.sinistra, data);
                System.out.print("a"); //testcase
        }
}
se togli i testcase puoi togliere le graffe e cosi il codice viene bellissimo
__________________
Voglio sapere di che tessuto deve essere un discorso per non fare neanche una piega
Alternativa ai pacchi di NLITE
MacBook & Canon Ixus 80

Ultima modifica di feboss : 29-06-2008 alle 20:26.
feboss è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Hisense A85N: il ritorno all’OLED è convincente e alla portata di tutti Hisense A85N: il ritorno all’OLED è convi...
Recensione Borderlands 4, tra divertimento e problemi tecnici Recensione Borderlands 4, tra divertimento e pro...
TCL NXTPAPER 60 Ultra: lo smartphone che trasforma la lettura da digitale a naturale TCL NXTPAPER 60 Ultra: lo smartphone che trasfor...
Un fulmine sulla scrivania, Corsair Sabre v2 Pro ridefinisce la velocità nel gaming Un fulmine sulla scrivania, Corsair Sabre v2 Pro...
Nokia Innovation Day 2025: l’Europa ha bisogno di campioni nelle telecomunicazioni Nokia Innovation Day 2025: l’Europa ha bisogno d...
The Social Reckoning: il seguito di The ...
iPhone 16 si trova ora su Amazon a soli ...
Amazon fa a pezzi i prezzi dei monitor g...
Componenti hardware e periferiche PC a p...
Pianeta in crisi: 7 su 9 limiti vitali g...
Galaxy S25 FE con taglio di prezzo di 10...
4 robot aspirapolvere e 3 scope elettric...
Nuovissimi Xiaomi 15T e 15T Pro con tagl...
Le agenzie federali americane potranno u...
Smartphone pieghevoli sempre più ...
LG svela le Easy TV, una nuova gamma di ...
L'equipaggio della missione Shenzhou-20 ...
Possibili detriti spaziali del razzo cin...
Amazon distrugge i prezzi: TV OLED LG, i...
Trump studia dazi fino al 100% per sping...
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: 02:24.


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