Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Dreame X60 Pro Ultra Complete: i bracci si estendono sempre di più
Dreame X60 Pro Ultra Complete: i bracci si estendono sempre di più
Dreame X60 Pro Ultra Complete implementa due bracci estensibili, per spazzola e moccio, che si spingono ben oltre quanto visto sino ad oggi permettendo una pulizia di casa ancor più capillare e precisa
TCL 65C8L, la recensione del SQD-Mini LED da 4400 nit misurati
TCL 65C8L, la recensione del SQD-Mini LED da 4400 nit misurati
La tecnologia SQD-Mini LED di TCL arriva sul taglio da 65 pollici con la serie C8L: 2040 zone, pannello WHVA 2.0 e un picco che alle rilevazioni delle sonde tocca i 4400 nit nel profilo Filmmaker e un HDR quasi perfetto
MSI Maestro 500 Wireless: ANC e 90 ore di autonomia a 70 euro
MSI Maestro 500 Wireless: ANC e 90 ore di autonomia a 70 euro
Wireless 2.4 GHz, Bluetooth 5.4, cancellazione attiva del rumore, design pieghevole e un'autonomia che mette in imbarazzo prodotti che costano il doppio. Le Maestro 500 non eccellono in nulla, ma offrono tutto. E a questo prezzo è difficile chiedere di più
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 28-01-2014, 20:10   #1
Marcoz91
Junior Member
 
Iscritto dal: Jan 2014
Messaggi: 5
Confrontare due oggetti di un array

Salve a tutti !
Mi sono appena iscritto su questo forum perchè non ho molta dimestichezza con il linguaggio java, e sarei molto grato se qualcuno di voi potesse darmi una mano =)

Il mio problema è questo :
ho creato una classe generica di tipo studente .
la classe contiene i seguenti attributi :
String nome;
String cognome;
int eta;.

Dopo aver dichiarato costruttore e aver sviluppato i soliti metodi get e set, ho creato un array di tipo studente:
studente [] vet = new studente [n];

Solo che adesso non riesco a confrontare gli elementi dello stesso array per trovare il piu' piccolo in base al campo età.

ho pensato di fare qualcosa del tipo :
if (vet[i].get_eta() < vet [i+1].get_eta()) ma non so come passare il valore dell'indice della posizione dell'elemento piu' piccolo nel main , in modo da poterlo visualizzare !

Ultima modifica di Marcoz91 : 28-01-2014 alle 20:31.
Marcoz91 è offline   Rispondi citando il messaggio o parte di esso
Old 28-01-2014, 22:10   #2
clockover
Senior Member
 
L'Avatar di clockover
 
Iscritto dal: Oct 2004
Messaggi: 1945
Quote:
Originariamente inviato da Marcoz91 Guarda i messaggi
ma non so come passare il valore dell'indice della posizione dell'elemento piu' piccolo nel main , in modo da poterlo visualizzare !
Sai che questo non l'ho capito? Per piacere sii più preciso. Cosa devi fare?
clockover è offline   Rispondi citando il messaggio o parte di esso
Old 28-01-2014, 23:25   #3
Oceans11
Senior Member
 
L'Avatar di Oceans11
 
Iscritto dal: Sep 2005
Città: Torino
Messaggi: 606
Se ho capito cosa intendi, stai sbagliando algoritmo.
Pensala così:

Codice:
Il primo Studente dell'array è quello più piccolo di età.
Per ogni Studente (dal secondo in poi)
    - verifica se l'età dello Studente i-esimo è minore di quella del più piccolo
    - in caso affermativo, l'i-esimo Studente (quello corrente) è il più piccolo, salvalo.
    - altrimenti continua con il prossimo studente.
__________________
"Se proprio dovete piratare un prodotto, preferiamo che sia il nostro piuttosto che quello di qualcun altro." [Jeff Raikes]
"Pirating software? Choose Microsoft!"
Oceans11 è offline   Rispondi citando il messaggio o parte di esso
Old 29-01-2014, 06:21   #4
Marcoz91
Junior Member
 
Iscritto dal: Jan 2014
Messaggi: 5
Praticamente la traccia mi dice di trovare , nell'array vet di tipo studente, l'elemento con l'età minore, il piu' giovane per intederci.
Solo che non riesco a confrontare gli oggetti dell'array tra di loro per trovare il minore.
Marcoz91 è offline   Rispondi citando il messaggio o parte di esso
Old 29-01-2014, 07:24   #5
clockover
Senior Member
 
L'Avatar di clockover
 
Iscritto dal: Oct 2004
Messaggi: 1945
Quote:
Originariamente inviato da Marcoz91 Guarda i messaggi
Praticamente la traccia mi dice di trovare , nell'array vet di tipo studente, l'elemento con l'età minore, il piu' giovane per intederci.
Solo che non riesco a confrontare gli oggetti dell'array tra di loro per trovare il minore.
Allora quello che hai scritto è giusto
Codice:
vett[i].getEta() <>=ecc.. vett[j].getEta()
altrimenti, se sai che sarà solo e sempre l'età ad essere comparata, puoi implementare l'interfaccia Comparable
clockover è offline   Rispondi citando il messaggio o parte di esso
Old 29-01-2014, 07:30   #6
Marcoz91
Junior Member
 
Iscritto dal: Jan 2014
Messaggi: 5
Ci stavo pensando, ma alla fine ho deciso di confrontare solamente le get.
Il problema è che ecplise mi segna ques'ultimo confronto come errore, e in piu' non riesco nemmeno a visualizzare l'elemento con l'età minore.
Marcoz91 è offline   Rispondi citando il messaggio o parte di esso
Old 29-01-2014, 07:38   #7
clockover
Senior Member
 
L'Avatar di clockover
 
Iscritto dal: Oct 2004
Messaggi: 1945
Quote:
Originariamente inviato da Marcoz91 Guarda i messaggi
Ci stavo pensando, ma alla fine ho deciso di confrontare solamente le get.
Il problema è che ecplise mi segna ques'ultimo confronto come errore, e in piu' non riesco nemmeno a visualizzare l'elemento con l'età minore.
Si ma devi essere più preciso. Mostra almeno il codice (indentato per piacere)
clockover è offline   Rispondi citando il messaggio o parte di esso
Old 29-01-2014, 07:45   #8
Marcoz91
Junior Member
 
Iscritto dal: Jan 2014
Messaggi: 5
package uni;

public class metodi {

public static void minore (studenti[]vet) {
//variabile che conterrà l'indice dell'elemento piu' piccolo
int min = 0;
//indice array
int i=0;
for (i=0;i<vet.length;i++){
if (vet[i].get_eta()< vet[i-1].get_eta()){
min=i;
}
else {
min=i+1;
}

}
System.out.println("lo studente piu giovane e"+vet[min]);

}

}



E NELLA CLASSE PRINCIPALE, OVVERO NEL MAIN, RICHIAMO IL METODO:

metodi.minore(vet)

SOLO CHE QUANDO VADO IN COMPILAZIONE, ECLIPSE MI RILEVA UN ERRORE NEL CONFRONTO "(vet[i].get_eta()< vet[i-1].get_eta()"
SCUSATE MA NON SAPEVO COME ALLEGARE IL FILE DI TESTO SINGOLO
Marcoz91 è offline   Rispondi citando il messaggio o parte di esso
Old 29-01-2014, 07:58   #9
clockover
Senior Member
 
L'Avatar di clockover
 
Iscritto dal: Oct 2004
Messaggi: 1945
Codice:
public class metodi {

    public static void minore(studenti[] vet) {
        //variabile che conterrà l'indice dell'elemento piu' piccolo
        int min = 0;
        //indice array
        int i = 0;
        for (i = 0; i < vet.length; i++) {
            if (vet[i].get_eta() < vet[i - 1].get_eta()) {
                min = i;
            } else {
                min = i + 1;
            }

        }
        System.out.println("lo studente piu giovane e" + vet[min]);

    }

}
QUESTO E' UN CODICE INDENTATO


Se io ho questo codice
Codice:
for(int i = 0; i < len; i++)
    if(vett[i] < vatt[i - 1])....
c'è qualcosa che non va. Il tuo indice i parte da 0, quindi il primo confronto già non va bene perchè ti troveresti con un indice a -1 al primo confronto.

Puoi seguire un'altra linea comunque.
1) prendi come elemento più piccolo il primo dell'array, e quindi ti segni l'indice, che per il momento è il minore
2) scorri l'array a partire dall'indice 1

Per ora non ti dico di più. Vediamo i progressi..
clockover è offline   Rispondi citando il messaggio o parte di esso
Old 29-01-2014, 12:56   #10
Marcoz91
Junior Member
 
Iscritto dal: Jan 2014
Messaggi: 5
Scusate, ho capito da solo il mio errore.
Ho sbagliato semplicemente il passaggio dei parametri, e quindi non riuscivo a stampare l'elemento
Marcoz91 è offline   Rispondi citando il messaggio o parte di esso
Old 29-01-2014, 14:34   #11
clockover
Senior Member
 
L'Avatar di clockover
 
Iscritto dal: Oct 2004
Messaggi: 1945
Vedi che quel metodo è completamente sbagliato

Inviato da una supercazzola ed un Nexus 5 scappellato a sinistra.. con senso unico
clockover è offline   Rispondi citando il messaggio o parte di esso
Old 01-02-2014, 15:39   #12
Deep thought
Junior Member
 
Iscritto dal: Aug 2013
Messaggi: 24
Come ti sta dicendo clockover, devi confrontare l'elemento che al momento conosci come il più piccolo con tutti i suoi successivi. In pratica:
  1. scegli il primo elemento;
  2. lo memorizzi in una variabile "Studente min";
  3. In un ciclo for in cui scansioni tutti gli elementi dell'array, a ogni esecuzione del ciclo fai questa valtazione:
    • se il valore all'indice i è maggiore di min, passa avanti;
    • se il valore all'indice i è minore di min, assegna min = vett[i].get_eta().
  4. al termine del ciclo for, la variabile min è il riferimento al valore più piccolo.

Se invece non devi ottenere un riferimento all'oggetto Studente con età minore, ma semplicemente trovare il suo indice nell'array, allora basta modificare di poco l'algoritmo, in modo da assegnare alla variabile min non più lo studente, ma il suo indice in vett.

E poi prima di affrontare la programmazione orientata agli oggetti dovresti accertarti di essere già a tuo agio con gli algoritmi di base come questo... quello che hai scritto tu, oltre a non funzionare, restituirà sempre un'eccezione ArrayIndexOutOfBounds perché al primo ciclo cerca di accedere a vett[-1].

Ultima modifica di Deep thought : 01-02-2014 alle 15:47.
Deep thought è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Dreame X60 Pro Ultra Complete: i bracci si estendono sempre di più Dreame X60 Pro Ultra Complete: i bracci si esten...
TCL 65C8L, la recensione del SQD-Mini LED da 4400 nit misurati TCL 65C8L, la recensione del SQD-Mini LED da 440...
MSI Maestro 500 Wireless: ANC e 90 ore di autonomia a 70 euro MSI Maestro 500 Wireless: ANC e 90 ore di autono...
NL-LC1 è il primo dissipatore a liquido AIO di Noctua: silenzio è la parola d'ordine NL-LC1 è il primo dissipatore a liquido A...
Boox Go 10.3 (Gen II) Lumi: il tablet e-ink con Android 15 e penna, dal prezzo super Boox Go 10.3 (Gen II) Lumi: il tablet e-ink con ...
Microsoft conferma bug nel Cestino in tu...
Accenture crolla del 20% in borsa, il pe...
ASUS Pro WS W890E-SAGE SE: sette PCIe 5....
Attenzione al prezzo di questa TV Hisens...
Chrome sbeffeggiato da Ballmer nel 2009:...
Un gioco Mac compatibile con Apple Silic...
La batteria allo stato solido di Honda s...
Google a ricercatore di sicurezza: 'Bel ...
MapTap vi farà impazzire: è...
7Artisans Dream Cine Lens: tre ottiche T...
Torna l'e-bike Engwe più economic...
OnePlus aggiorna la gamma con un nuovo t...
Samsung nel caos: dipendenti in nero pro...
Lexar da 2TB PCIe 4.0 in offerta Amazon ...
Samsung Odyssey G5 in offerta Amazon: mo...
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: 15:02.


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