Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Sony INZONE H6 Air: il primo headset open-back di Sony per giocatori
Sony INZONE H6 Air: il primo headset open-back di Sony per giocatori
Il primo headset open-back della linea INZONE arriva a 200 euro con driver derivati dalle cuffie da studio MDR-MV1 e un peso record di soli 199 grammi
Nutanix cambia pelle: dall’iperconvergenza alla piattaforma full stack per cloud ibrido e IA
Nutanix cambia pelle: dall’iperconvergenza alla piattaforma full stack per cloud ibrido e IA
Al .NEXT 2026 di Chicago, Nutanix ha mostrato quanto sia cambiata: una piattaforma software che gestisce VM, container e carichi di lavoro IA ovunque, dall’on-premise al cloud pubblico. Con un’esecuzione rapidissima sulle partnership e sulla migrazione da VMware
Recensione Xiaomi Pad 8 Pro: potenza bruta e HyperOS 3 per sfidare la fascia alta
Recensione Xiaomi Pad 8 Pro: potenza bruta e HyperOS 3 per sfidare la fascia alta
Xiaomi Pad 8 Pro adotta il potente Snapdragon 8 Elite all'interno di un corpo con spessore di soli 5,75 mm e pannello LCD a 144Hz flicker-free, per un tablet che può essere utilizzato con accessori dedicati di altissima qualità. Fra le caratteristiche esclusive, soprattutto per chi intende usarlo con la tastiera ufficiale, c'è la modalità Workstation di HyperOS 3, che trasforma Android in un sistema operativo con interfaccia a finestre
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 31-05-2009, 21:46   #1
javacomelava
Member
 
Iscritto dal: May 2009
Messaggi: 129
[JAVA] Problemuccio con iteratore

Salve ragazzi.

Ho implementato una classe: CollezioneDiOrdinabili (che vuole rappresentare e gestire delle collezioni che siano formate di soli oggetti Ordinabili):

Codice:
import java.util.*;

public class CollezioneOrdinabili{
	
	private Ordinabile[] elem;
	
	public CollezioneOrdinabili(int n){
		if(n<=0)throw new FailureException("ERRORE: parametro errato!!!\n");
		elem=new Ordinabile[n];	
	}

       

        public boolean inserisci(Ordinabile X){
		Class C=null;
		boolean ins=false;
		if(elem[0]==null)
			elem[0]=X;
		else{
			C=X.getClass();
			for(int i=1;i<elem.length && ins==false;i++){
				if(elem[i]==null && C.isInstance(elem[0])){
					elem[i]=X;
					ins=true;
				}
			}
		}
		return ins;
	}


         public String toString(){
		String header="\nCOLLEZIONE DI ORDINABILI:\n";
		String temp="";
		String fine="";
		for(int i=0;i<elem.length;i++){
			if(elem[i]!=null){
				temp=elem[i].toString();
				fine=fine+temp;
			}
		}
		header=header+fine;
		return header;
	}
Per fare ciò ho creato una interfaccia Ordinabile:

Codice:
public interface Ordinabile{

	boolean maggioreDi(Ordinabile X);
	
}
Ho creato quindi una mia classe "stupida" che implementi l'interfaccia Ordinabile:

Codice:
public class MiaStringa implements Ordinabile{
	
	private String str;
	
	public MiaStringa(String s){
		str=s;
	}
	
	public String getStringa(){
		return str;
	}
	
	public String toString(){
		String ris="\nSTRINGA: "+this.getStringa()+"\n";
		return ris;
	}
	
        /** this è maggiore di X se length() di this > length di X */
	public boolean maggioreDi(Ordinabile X){
		boolean md=false;
		if(X instanceof MiaStringa){
			int lung_this=this.getStringa().length();
			int lung_X=((MiaStringa)X).getStringa().length();
			if(lung_this>lung_X)
				md=true;
			}
		return md;
	}
}
Fin qui tutto bene.
Ho deciso poi di voler implementare all'interno di CollezioneDiOrdinabili un ITERATORE che mi restituisse gli elementi della collezione ORDINATAMENTE.
Ed è qui che sono andato nel pallone....non ci riesco...

Codice:
private class MioIteratore implements Iterator{
		
		private int min;
		
		public MioIteratore(){
			if(elem[0]==null)throw new FailureException("ERRORE:                   collezione vuota!!!\n");
			Ordinabile pic=elem[0];
			min=0;
			for(int i=0;i<elem.length;i++){
				if(elem[i]!=null && (!(elem[i].maggioreDi(pic)))){
					pic=elem[i];
					min=i;
				}
			}
		}
		
		public Object next(){
			return elem[min];
		}
		
		public boolean hasNext(){
			boolean b=false;
			for(int i=0;i<elem.length && b==false ;i++){
				if(elem[i].maggioreDi(elem[min]))
					b=true;
				}
			return b;
		}	
			
		public void remove(){
                
                }
Praticamente l'ho pensata cosi:

l'iteratore ha una variabile d'istanza che rappresenta il minimo.
Quindi il costruttore dell'iteratore inizializza la var d'istanza assegnandogli l'indice del'array dov'e' contenuto il minimo.

next() restituisce semplicemtente il minimo attuale.
hasNext() controlla se all'interno dell'array c'e' un valore maggiore del minimo.ciò significherebbe che quel valore ancora non è stato considerato e quindi hasNext() restituisce true.

remove() mi sta facendo impazzire!!! Io l'ho pensata cosi:
dovrebbe cercare nell'array il VALORE PIU PICCOLO TRA GLI ELEMENTI CHE SIANO ALLO STESSO TEMPO ANCHE MAGGIORI DEL MINIMO ATTUALE.Ma come fare questa cosa??? ci ho scapocciato per tutto il giorno....ma sono sommerso da loop infiniti.....

Spero qualcuno riesca ad aiutarmi....alla fine sono sicuro che sto impazzendo per qualche stupidaggine.

SAluti e grazie per l'aiuto!

Ultima modifica di javacomelava : 01-06-2009 alle 15:31.
javacomelava è offline   Rispondi citando il messaggio o parte di esso
Old 01-06-2009, 14:52   #2
javacomelava
Member
 
Iscritto dal: May 2009
Messaggi: 129
nessuno che mi dà una bella dritta ?
javacomelava è offline   Rispondi citando il messaggio o parte di esso
Old 01-06-2009, 15:18   #3
e-commerce84
Senior Member
 
Iscritto dal: Feb 2009
Messaggi: 700
Ora stò studiando per il mio esame di Java ed ero venuto quì a postare...dopo se non ti hanno ancora risposto vedo di dargli un'occhiata...promesso...tanto è utile anche a me...

[OT]Per caso studi a tor Vergata?[/OT]
e-commerce84 è offline   Rispondi citando il messaggio o parte di esso
Old 01-06-2009, 15:28   #4
javacomelava
Member
 
Iscritto dal: May 2009
Messaggi: 129
prof m.d.i. ???? ehehehe
javacomelava è offline   Rispondi citando il messaggio o parte di esso
Old 01-06-2009, 15:53   #5
e-commerce84
Senior Member
 
Iscritto dal: Feb 2009
Messaggi: 700
Quote:
Originariamente inviato da javacomelava Guarda i messaggi
prof m.d.i. ???? ehehehe
mmm non ho capito cosa intendi dire...stai a torvergata anche te? che facoltà? Come esercizzi mi sembra piuttosto simile a quelli dati dalla mia proff di metodologie di programmazione ad informatica
e-commerce84 è offline   Rispondi citando il messaggio o parte di esso
Old 01-06-2009, 15:56   #6
javacomelava
Member
 
Iscritto dal: May 2009
Messaggi: 129
hai (anzi..abbiamo) l'esame l'8 giugno e le iniziali della prof sono m.d.i ... questo intendevo....siamo sulla stessa barca
javacomelava è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Sony INZONE H6 Air: il primo headset open-back di Sony per giocatori Sony INZONE H6 Air: il primo headset open-back d...
Nutanix cambia pelle: dall’iperconvergenza alla piattaforma full stack per cloud ibrido e IA Nutanix cambia pelle: dall’iperconvergenza alla ...
Recensione Xiaomi Pad 8 Pro: potenza bruta e HyperOS 3 per sfidare la fascia alta Recensione Xiaomi Pad 8 Pro: potenza bruta e Hyp...
NZXT H9 Flow RGB+, Kraken Elite 420 e F140X: abbiamo provato il tris d'assi di NZXT NZXT H9 Flow RGB+, Kraken Elite 420 e F140X: abb...
ASUS ROG Swift OLED PG34WCDN recensione: il primo QD-OLED RGB da 360 Hz ASUS ROG Swift OLED PG34WCDN recensione: il prim...
Nasce DIVE - Driving Innovation in Venet...
Fastweb entra tra i partner di Starlink ...
Tesla completa il tape-out del chip AI5:...
App falsa di Ledger Live sull'App Store ...
Svelato il prezzo dell'e-bike che sostit...
ASML vola grazie all'AI: numeri oltre le...
Google lancia l'app nativa per Windows: ...
'Non dovremmo lasciarli entrare nel nost...
Windows 11 25H2 e 24H2, build 26200.8246...
Windows 10, il nuovo aggiornamento estes...
Microsoft potrebbe tornare a puntare sul...
Undervolt con un clic: NV-UV ottimizza l...
L'Italia finanzia CamGraPhIC (2D Photoni...
Google Chrome introduce le Skills, per a...
Dalla RAM agli SSD: il ruolo dell'ECC ne...
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: 10:48.


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