Torna indietro   Hardware Upgrade Forum > Software > Programmazione

AWS annuncia European Sovereign Cloud, il cloud sovrano per convincere l'Europa
AWS annuncia European Sovereign Cloud, il cloud sovrano per convincere l'Europa
AWS è il principale operatore di servizi cloud al mondo e da tempo parla delle misure che mette in atto per garantire una maggiore sovranità alle organizzazioni europee. L'azienda ha ora lanciato AWS European Sovereign Cloud, una soluzione specificamente progettata per essere separata e distinta dal cloud "normale" e offrire maggiori tutele e garanzie di sovranità
Redmi Note 15 Pro+ 5G: autonomia monstre e display luminoso, ma il prezzo è alto
Redmi Note 15 Pro+ 5G: autonomia monstre e display luminoso, ma il prezzo è alto
Xiaomi ha portato sul mercato internazionale la nuova serie Redmi Note, che rappresenta spesso una delle migliori scelte per chi non vuole spendere molto. Il modello 15 Pro+ punta tutto su una batteria capiente e su un ampio display luminoso, sacrificando qualcosa in termini di potenza bruta e velocità di ricarica
HONOR Magic 8 Pro: ecco il primo TOP del 2026! La recensione
HONOR Magic 8 Pro: ecco il primo TOP del 2026! La recensione
HONOR ha finalmente lanciato il suo nuovo flagship: Magic 8 Pro. Lo abbiamo provato a fondo in queste settimane e ve lo raccontiamo nella nostra recensione completa. HONOR rimane fedele alle linee della versione precedente, aggiungendo però un nuovo tasto dedicato all'AI. Ma è al suo interno che c'è la vera rivoluzione grazie al nuovo Snapdragon 8 Elite Gen 5 e alla nuova MagicOS 10
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 28-01-2014, 21: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 21:31.
Marcoz91 è offline   Rispondi citando il messaggio o parte di esso
Old 28-01-2014, 23: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 29-01-2014, 00: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, 07: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, 08: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, 08: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, 08: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, 08: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, 08: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, 13: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, 15: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, 16: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 16:47.
Deep thought è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


AWS annuncia European Sovereign Cloud, il cloud sovrano per convincere l'Europa AWS annuncia European Sovereign Cloud, il cloud ...
Redmi Note 15 Pro+ 5G: autonomia monstre e display luminoso, ma il prezzo è alto Redmi Note 15 Pro+ 5G: autonomia monstre e displ...
HONOR Magic 8 Pro: ecco il primo TOP del 2026! La recensione HONOR Magic 8 Pro: ecco il primo TOP del 2026! L...
Insta360 Link 2 Pro e 2C Pro: le webcam 4K che ti seguono, anche con gimbal integrata Insta360 Link 2 Pro e 2C Pro: le webcam 4K che t...
Motorola edge 70: lo smartphone ultrasottile che non rinuncia a batteria e concretezza Motorola edge 70: lo smartphone ultrasottile che...
Vast prosegue la costruzione della stazi...
Chiarito cosa è successo al satel...
Il TAR annulla Bologna Città 30. ...
Laptop con chip NVIDIA da marzo? Emergon...
Costruito in casa, più veloce di ...
Il nuovo Galaxy Book 6 Pro costa il 25% ...
C'è un boom del mercato dei data ...
OVHcloud annuncia la disponiiblità...
Il Wi-Fi 7 ha un nuovo re: da ASUS arriv...
In arrivo l'auto "Frankenstein"...
Chip NVIDIA H200 in Cina? 'Come vendere ...
iPhone 16 torna super conveniente: ora c...
Offerte Amazon pazzesche: tech, smartpho...
Ubisoft annuncia l'arrivo dei 60 fps per...
Infratel Italia: ecco la nuova mappa del...
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: 07:21.


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