Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Sottile, leggero e dall'autonomia WOW: OPPO Reno14 F conquista con stile e sostanza
Sottile, leggero e dall'autonomia WOW: OPPO Reno14 F conquista con stile e sostanza
OPPO Reno14 F 5G si propone come smartphone di fascia media con caratteristiche equilibrate. Il device monta processore Qualcomm Snapdragon 6 Gen 1, display AMOLED da 6,57 pollici a 120Hz, tripla fotocamera posteriore con sensore principale da 50MP e generosa batteria da 6000mAh con ricarica rapida a 45W. Si posiziona come alternativa accessibile nella gamma Reno14, proponendo un design curato e tutto quello che serve per un uso senza troppe preoccupazioni.
Destiny Rising: quando un gioco mobile supera il gioco originale
Destiny Rising: quando un gioco mobile supera il gioco originale
Tra il declino di Destiny 2 e la crisi di Bungie, il nuovo titolo mobile sviluppato da NetEase sorprende per profondità e varietà. Rising offre ciò che il live service di Bungie non riesce più a garantire, riportando i giocatori in un universo coerente. Un confronto che mette in luce i limiti tecnici e strategici dello studio di Bellevue
Plaud Note Pro convince per qualità e integrazione, ma l’abbonamento resta un ostacolo
Plaud Note Pro convince per qualità e integrazione, ma l’abbonamento resta un ostacolo
Plaud Note Pro è un registratore digitale elegante e tascabile con app integrata che semplifica trascrizioni e riepiloghi, offre funzioni avanzate come template e note intelligenti, ma resta vincolato a un piano a pagamento per chi ne fa un uso intensivo
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 18-08-2008, 12:14   #1
luxorl
Senior Member
 
L'Avatar di luxorl
 
Iscritto dal: Oct 2003
Città: Pisa/Cosenza
Messaggi: 1364
[Java] Alberi Binari: Ridefinire Iteratore per visita Postfissa

Ciao a tutti.
Ho ridefinito l'Iterator di Java per poter iterare su un albero binario.
Ho alcuni problemi a far muovere l'iteratore mediante visita postfissa.
In particolare, sulle foglie ho implementato i seguenti metodi:

Codice:
	public class ICostante extends IEspressione implements Iterator<Espressione> {
	
	boolean flag=true;
	
	public ICostante(Costante c) {
		this.exp=c;
		//this.it=c.iterator();
	}

	public boolean hasNext() { return this.flag; }

	public Espressione next() {
		if(flag){
			this.flag=false;
			return exp;
		}
		
		throw new NoSuchElementException();
	}

}
Mentre nei nodi non terminali ho scritto questo codice:


Codice:
	public class IOperatorePostfisso extends IOperatore {
	
	private final int SINISTRA=0, DESTRA=1;
	private int puntatore=SINISTRA;

	public IOperatorePostfisso(Operatore o) {
		super(o);
	}
	
	public boolean hasNext(){
		if(puntatore==DESTRA) return it.hasNext();
		return true;
	}
	
	public Espressione next(){
		if(it==null) this.it=exp.getLeft().iterator(); 
		if(it.hasNext()) return it.next();
		if(puntatore==SINISTRA){
			puntatore=DESTRA;
			it=exp.getRight().iterator();
			if(it.hasNext()) return it.next();
			else return exp; //nodo non terminale operatore
		}
		
		throw new NoSuchElementException();
		
	}
Però ho problemi a ridefinirmi il next(). Ho provato in questo modo ma mi ritorna (con visita postfissa) solo le foglie.

Per esempio se inserisco la seguente espressione: 4+5*3
L'iteratore mi stampa: 4 5 3

Perché non mi ritorna mai exp quando è un operatore?
__________________
luxorl è offline   Rispondi citando il messaggio o parte di esso
Old 18-08-2008, 12:54   #2
luxorl
Senior Member
 
L'Avatar di luxorl
 
Iscritto dal: Oct 2003
Città: Pisa/Cosenza
Messaggi: 1364
Allora, ho capito l'errore che sta nel metodo hasNext()
Che in caso di Puntatore a destra non deve ritornare l'hasNext() del figlio ma una propria flag che segnala se l'operatore stesso è stato già ritornato.
Questo perché nella visita postfissa l'ultimo ad essere ritornato è il nodo padre e non il figlio destro. A parole non mi spiego molto bene meglio incollare il codice corretto.

Codice:
public class IOperatorePostfisso extends IOperatore {
	
	private final int SINISTRA=0, DESTRA=1;
	private int puntatore=SINISTRA;
	private boolean flag=false;

	public IOperatorePostfisso(Operatore o) {
		super(o);
	}
	
	public boolean hasNext(){		 
		if(puntatore==DESTRA) return !flag;		
		return true;
	}
	
	public Espressione next(){
		if(it==null) this.it=exp.getLeft().iterator(); 
		if(it.hasNext()) return it.next();
		if(puntatore==SINISTRA){
			puntatore=DESTRA;
			it=exp.getRight().iterator();
			if(it.hasNext()) return it.next();
		}
		if(puntatore==DESTRA){
			flag=true;
			return exp;
		}
		
		throw new NoSuchElementException();
		
	}
Prima non mi stampava mai l'operatore perché quando il padre chiedeva hasNext sul figlio questo lo richiedeva al suo figlio DX e se questo tornava false, perché era stato già restituito, e il metodo next() non veniva proprio invocato sull'operatore.
__________________

Ultima modifica di luxorl : 18-08-2008 alle 12:56.
luxorl è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Sottile, leggero e dall'autonomia WOW: OPPO Reno14 F conquista con stile e sostanza Sottile, leggero e dall'autonomia WOW: OPPO Reno...
Destiny Rising: quando un gioco mobile supera il gioco originale Destiny Rising: quando un gioco mobile supera il...
Plaud Note Pro convince per qualità e integrazione, ma l’abbonamento resta un ostacolo Plaud Note Pro convince per qualità e int...
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...
Traguardo Omoda & Jaecoo in Italia: ...
EHT mostra nuove immagini di come cambia...
Il gioiellino di Fastned: aperti in Belg...
La nuova mini workstation AI di MinisFor...
Formula 1 2026, nuove gare Sprint in cal...
MacBook Pro con display OLED e supporto ...
Poste Italiane: dati di milioni di utent...
Microsoft blocca RaccoonO365, rubate olt...
15 anni dopo Skate 3, il gioco torna sot...
Molte novità per MongoDB: version...
Cina, stop alle GPU NVIDIA: Pechino inti...
Google Pixel 10 con sconti super: ecco q...
Apple Mac mini con chip M4 a soli 598€ s...
DJI firma la rivoluzione: ecco il Mini 5...
Si spara in Friuli Venezia Giulia, ma so...
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: 17:29.


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