Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Recensione vivo X300 Pro: è ancora lui il re della fotografia mobile, peccato per la batteria
Recensione vivo X300 Pro: è ancora lui il re della fotografia mobile, peccato per la batteria
vivo X300 Pro rappresenta un'evoluzione misurata della serie fotografica del produttore cinese, con un sistema di fotocamere migliorato, chipset Dimensity 9500 di ultima generazione e l'arrivo dell'interfaccia OriginOS 6 anche sui modelli internazionali. La scelta di limitare la batteria a 5.440mAh nel mercato europeo, rispetto ai 6.510mAh disponibili altrove, fa storcere un po' il naso
Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'' per spingere gli handheld gaming PC al massimo
Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'' per spingere gli handheld gaming PC al massimo
Lenovo Legion Go 2 è la nuova handheld PC gaming con processore AMD Ryzen Z2 Extreme (8 core Zen 5/5c, GPU RDNA 3.5 16 CU) e schermo OLED 8,8" 1920x1200 144Hz. È dotata anche di controller rimovibili TrueStrike con joystick Hall effect e una batteria da 74Wh. Rispetto al dispositivo che l'ha preceduta, migliora ergonomia e prestazioni a basse risoluzioni, ma pesa 920g e costa 1.299€ nella configurazione con 32GB RAM/1TB SSD e Z2 Extreme
AWS re:Invent 2025: inizia l'era dell'AI-as-a-Service con al centro gli agenti
AWS re:Invent 2025: inizia l'era dell'AI-as-a-Service con al centro gli agenti
A re:Invent 2025, AWS mostra un’evoluzione profonda della propria strategia: l’IA diventa una piattaforma di servizi sempre più pronta all’uso, con agenti e modelli preconfigurati che accelerano lo sviluppo, mentre il cloud resta la base imprescindibile per governare dati, complessità e lock-in in uno scenario sempre più orientato all’hybrid cloud
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 06-09-2005, 10:21   #1
Asragon
Junior Member
 
Iscritto dal: Aug 2005
Messaggi: 11
[java] ordinamento istanze di un vettore[java]

salve a tutti, ho un problema da risolvere..
ho un vettore
Vector a=new Vector();
e dentro questo vettore ho delle istanze della classe Persona,quindi ogni istanza avrà come attributi nome cognome eta e anno di nascita.
ora il mio problema è questo:
dati queste istanze di persona nel vettore a ,come faccio a ordinarle nel vettore prima per età e poi per anno?
è possibile farlo? oppure c'e un altra via non usando il vettore e cmq avendo queste istanze raggruppate e con possibilità di ordinarle?


grazie in anticipo dell'aiuto.
buon proseguimento di giornata
Asragon è offline   Rispondi citando il messaggio o parte di esso
Old 06-09-2005, 10:30   #2
pinok
Senior Member
 
Iscritto dal: Jun 2001
Città: Alessandria (provincia)
Messaggi: 4772
Devi cercare l'algoritmo di quick sort e implementare il confronto tra oggetti secondo le tue esigenze.
In pratica questo confronto prende gli oggetti due a due e stabilisce quale dei due deve precedere l'altro.
Con questa informazione l'algoritmo di quick sort provvede al riordino.
pinok è offline   Rispondi citando il messaggio o parte di esso
Old 06-09-2005, 10:37   #3
Asragon
Junior Member
 
Iscritto dal: Aug 2005
Messaggi: 11
ok questo si.. sapevo di utilizzare il quicksort, il problema è che non so come dire di ordinare il vettore secondo l attributo età delle istanze di classe Persona che sono nel vettore
Asragon è offline   Rispondi citando il messaggio o parte di esso
Old 06-09-2005, 11:57   #4
pinok
Senior Member
 
Iscritto dal: Jun 2001
Città: Alessandria (provincia)
Messaggi: 4772
Gli esempi standard del quick sort ordinano oggetti numerici.
Devi modificarlo in modo che i controlli siano fatti esternamente in base ai criteri che vuoi tu.

Faccio prima a riportarti il codice. Ti serve una classe astratta che và bene per tutti gli ordinamenti

Codice:
import java.util.*;

public abstract class Ordina
{	
  /** 
   * 	Algoritmo di quickSorting, da inizializzare con il vettore da 
   *	ordinare e gli indici estremi del vettore 
   * 	(solitamente left = 0 e right = element.size()-1) 
   **/
  public void qs (Vector element, int left, int right) 
  {
    int i,j;
    Object x, y;
        
    i = left;
    j = right;
    x = element.elementAt((left+right)/2);
        
   do
   {
     while (minimum (element.elementAt(i), x) && i<right) i++;
     while (minimum (x, element.elementAt(j)) && j>left) j--;
            
     if (i<=j)
    {
       y = element.elementAt(i);
       element.setElementAt (element.elementAt(j), i);
       element.setElementAt (y, j);
       i++;
       j--;
      }
    } while (i<=j);
        
    if (left<j) qs (element, left, j);
    if (i<right) qs(element, i, right);
  }
	
  /**
   * Interfaccia da implementare di volta in volta
   *
   * @param obj1 Primo oggetto da confrontare
   * @param obj2 Secondo oggetto da confrontare
   */
  protected abstract boolean minimum(Object obj1, Object obj2);
}
Poi ti devi fare una classe che estende quella astratta ridefinendo il metodo minimum secondo le tue esigenze. Ad es, se i tuoi oggetti sono istanze di Studente con l'anagrafica di ognuno, per ordinare in base al cognome e nome (messi in uppercase per evitare differenze di ordinamento in base alle maiuscole):

Codice:
public class OrdinaStudenti extends Ordina
{	
   /**
    * Interfaccia da implementare di volta in volta
    *
    * @param obj1 Primo oggetto da confrontare 
    * @param obj2 Secondo oggetto da confrontare
    */
   protected boolean minimum(Object obj1, Object obj2)
   {
      String nome1 = ((Studente)obj1).getCognome().toUpperCase()+" "+((Studente)obj1).getNome().toUpperCase();
      String nome2 = ((Studente)obj2).getCognome().toUpperCase()+" "+((Studente)obj2).getNome().toUpperCase();
		
      if( nome1.compareTo(nome2)<0) return true;
      
      return false;
   }
}
Se hai da fare controlli più complicati, basta che li scrivi dentro al metodo minimum.
Se hai oggetti diversi da controllare, basta che crei nuove classi simili ad OrdinaStudenti perché qs và sempre bene per come è stato scritto (astratto).

Per richiamare l'ordinamento del vettore lista, devi solo scrivere:

Codice:
if (lista.size()>1) 
{
  OrdinaStudenti ordina = new OrdinaStudenti();
  ordina.qs(lista, 0, lista.size()-1);
}
Ricordati di mettere l'if (lista.size()>1) perché ti evita errori nel caso non ci fossero almeno 2 elementi (d'altra parte, che senso ha ordinare uno o zero elementi ??)
pinok è offline   Rispondi citando il messaggio o parte di esso
Old 06-09-2005, 12:05   #5
Asragon
Junior Member
 
Iscritto dal: Aug 2005
Messaggi: 11
mamma mia che bombardamento di informazioni .. sono inespertissimo di java.. ci mettero una vita per capire tutte queste cose comunque grazie infinite per l aiuto , siete i migliori
Asragon è offline   Rispondi citando il messaggio o parte di esso
Old 06-09-2005, 12:36   #6
anx721
Senior Member
 
L'Avatar di anx721
 
Iscritto dal: Oct 2002
Città: Roma
Messaggi: 1502
Java già mette a disposizione un algoritmo efficiente per ordinare una List e quindi anche un Vector.

Tutto ciò che devi fare è fare in modo che gli oggetti del tuo Vector (cioè Persona) implementino l'interface Comparable che richiede l'implementazione di un metodo:

public int compareTo(Object obj);

che deve ritornare:

1 - un numero negativo se questa persona è "minore" di quella passata come argomento
2 - zero se questa persona è "uguale" a quella passata come argomento
3 - un numero positivo se questa persona è "maggiore" di quella passata come argomento

E' sufficiente quindi aggiungere alla tua classe Pesrsona affinche i suoi oggetti siano confrontabili:

Codice PHP:
class Persona....implements Comparable{

     public 
int compareTo(Object obj){
          
Persona p = (Persona)obj;
          
//controlli per vedere se p è <, == o > rispetto a questo oggetto
     
}


Una volta fatto questo per ordinare un tuo vettore v è suffciente usare questa istruzione:

Collections.sort(v);
__________________
Sun Certified Java Programmer
EUCIP Core Level Certified

European Certification of Informatics Professionals

Ultima modifica di anx721 : 08-09-2005 alle 21:55.
anx721 è offline   Rispondi citando il messaggio o parte di esso
Old 08-09-2005, 18:37   #7
Asragon
Junior Member
 
Iscritto dal: Aug 2005
Messaggi: 11
allora io ho la classe MP3 come segue :
class Mp3 implements Serializable,Comparable
{
public String titolo;
public String artista;
public String album;
public int anno;
public String commento;

public int compareTo(Object obj)
{
if(! (obj instanceof Mp3))
return false;
Mp3 p = (Mp3)obj;
}
public Mp3() //costruttore della classe
{
this.titolo=titolo;
this.artista=artista;
this.album=album;
this.anno=anno;
this.commento=commento;
}
}

ora a parte che la stringa che ho sottileato mi da errore di incompatible types , per il resto come faccio poi a fare l ordinamento di un vettore che contiene queste istanze di questa classe?
vi prego è questione di vita o morte

inoltre come faccio poi a dire se p è <, == o > rispetto a questo oggetto ??

Ultima modifica di Asragon : 08-09-2005 alle 18:48.
Asragon è offline   Rispondi citando il messaggio o parte di esso
Old 08-09-2005, 22:04   #8
anx721
Senior Member
 
L'Avatar di anx721
 
Iscritto dal: Oct 2002
Città: Roma
Messaggi: 1502
Prima avevo sbagliato a scriverti l'esempio; il metodo compareTo fallo cosi:
Codice PHP:
public int compareTo(Object obj){
      
Mp3 p = (Mp3)obj;
     
//istruzioni per il confronto

Le istruzioni del confronto dipendono da come tu vuoi che venga eseguito il confronto tra gli oggetti Mp3: in base a quale criterio vuoi confrontarli? Quando un oggetto Mp3 m1 deve essere considerato minore di un oggetto Mp3 m2? Se ad esempio vuoi confrontare gli oggetti in base all'artista:
Codice PHP:
public int compareTo(Object obj){
     
Mp3 p = (Mp3)obj;
     
//istruzioni per il confronto
     
return artista.compareTo(p.artista);

in questo modo ritorni il risultato del confronto eseguito sui campi artista degli oggetti, che sono di tipo String, una classe che implementa Comparable.

Se volessi ordinarli in base all'artista, e a parità di artista, ordinarli rispetto al titolo:

Codice PHP:
public int compareTo(Object obj){
     
Mp3 p = (Mp3)obj;
     
int confrontoArtisti artista.compareTo(p.artista);
    
//se gli artisti non sono uguali...
    
if(confrontoArtisti != 0)
         return 
confrontoArtisti;
    
//se no si ritorna il risultato del confronto sul titolo
    
return titolo.compareTo(p.titolo);

una volta implementato tale metodo per ordinare il tuo vettore v basta eseguire:

Collections.sort(v);


Se poi volessi dinamicamente decidere se ordinare rispetto ad un campo piuttosto che un altro va seguita una soluzione leggermente diversa che prevede l'uso di un comparator da passare al metodo sort.
__________________
Sun Certified Java Programmer
EUCIP Core Level Certified

European Certification of Informatics Professionals
anx721 è offline   Rispondi citando il messaggio o parte di esso
Old 10-09-2005, 10:25   #9
Asragon
Junior Member
 
Iscritto dal: Aug 2005
Messaggi: 11
mm infatti io dovrei prima fare l ordinamento per anno e poi per artista. come posso fare?
Asragon è offline   Rispondi citando il messaggio o parte di esso
Old 10-09-2005, 13:53   #10
anx721
Senior Member
 
L'Avatar di anx721
 
Iscritto dal: Oct 2002
Città: Roma
Messaggi: 1502
Devi seguire l'esempio che ti ho dato, per ordinare per anno e poi per artista:

Codice PHP:
public int compareTo(Object obj){
     
Mp3 p = (Mp3)obj;
    if(
anno p.anno)
         return -
1;
    if(
anno p.anno)
         return 
1;
    
//se no si ritorna il risultato del confronto sugli artisti
    
return artista.compareTo(p.artista);

__________________
Sun Certified Java Programmer
EUCIP Core Level Certified

European Certification of Informatics Professionals
anx721 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Recensione vivo X300 Pro: è ancora lui il re della fotografia mobile, peccato per la batteria Recensione vivo X300 Pro: è ancora lui il...
Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'' per spingere gli handheld gaming PC al massimo Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'...
AWS re:Invent 2025: inizia l'era dell'AI-as-a-Service con al centro gli agenti AWS re:Invent 2025: inizia l'era dell'AI-as-a-Se...
Cos'è la bolla dell'IA e perché se ne parla Cos'è la bolla dell'IA e perché se...
BOOX Palma 2 Pro in prova: l'e-reader diventa a colori, e davvero tascabile BOOX Palma 2 Pro in prova: l'e-reader diventa a ...
Roscosmos ha posticipato (ancora) il lan...
Isar Aerospace si prepara al secondo lan...
Tory Bruno è entrato in Blue Orig...
Fujifilm lancia la cartuccia per archivi...
Dreame H15 Mix: la soluzione 7-in-1 per ...
AirPods Pro 3 in forte sconto su Amazon:...
36 offerte Amazon, molte appena partite:...
2 caricatori multipli eccezionali: da 28...
OLED e 360 Hz a un prezzo senza preceden...
Roborock Q10 S5+ a un prezzo molto conve...
Upgrade PC a prezzo ridotto: le migliori...
Sono i 6 smartphone migliori su Amazon: ...
Google Pixel 9a a 361€, mai così ...
Super sconti sugli spazzolini Oral-B, an...
Aspira a 6000Pa, lava bene, costa 139€: ...
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: 03:15.


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