Torna indietro   Hardware Upgrade Forum > Software > Programmazione

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
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.
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


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...
Ecovacs Deebot X11 Omnicyclone: niente più sacchetto per lo sporco Ecovacs Deebot X11 Omnicyclone: niente più...
Interlune creerà un centro di ric...
Stop Killing Games: 97% delle firme conv...
La GTX 2080 Ti mai arrivata sul mercato,...
Hoolow Knight: Silksong, il gioco che a ...
Duolingo crolla in Borsa: la minaccia ar...
Battlefield 6: i giocatori console potra...
Citroen Racing, la marca ritorna alle co...
Windows 10 ESU: come partecipare al prog...
ASUS Vivobook 16X a meno di 470€ su Amaz...
Con Agent Payments Protocol di Google gl...
Windows 10 muore, gli attivisti insorgon...
NVIDIA sarà il primo cliente di T...
Stellantis cancella il pick-up elettrico...
Microsoft termina il supporto per Office...
VaultGemma di Google è il primo 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: 19:48.


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