Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Gigabyte MO32U24 OLED: il 4K a 240Hz su un pannello OLED ideale per il gaming
Gigabyte MO32U24 OLED: il 4K a 240Hz su un pannello OLED ideale per il gaming
Pannello QD-OLED da 32 pollici con risoluzione 4K, frequenza di aggiornamento a 240Hz e tempi di risposta rapidissimi: il Gigabyte MO32U24 evolve il progetto del suo predecessore MO32U e alza ulteriormente l'asticella delle prestazioni. È ancora una volta un monitor indirizzato ai giocatori più esigenti
Recensione realme 16 5G: lo smartphone con Selfie Mirror ha una batteria da 6550mAh
Recensione realme 16 5G: lo smartphone con Selfie Mirror ha una batteria da 6550mAh
realme 16 5G è un nuovo smartphone con sensore Sony IMX 852 da 50MP sul retro e uno specchio selfie fisico integrato nella camera bar, una prima nel segmento di mercato. Batteria da 6550mAh in un corpo da 8,1mm e 183g, certificazione IP69K e ricarica da 45W completano un pacchetto aggressivo per la fascia media, per uno dei prodotti più interessanti del produttore sul piano commerciale
Come rispettare tutte le nuove regole per i monopattini elettrici? La guida per non rischiare sanzioni
Come rispettare tutte le nuove regole per i monopattini elettrici? La guida per non rischiare sanzioni
Sono ormai definitive le nuove norme del Codice della Strada per i monopattini elettrici. Non solo targa e assicurazione, le regole sono tante e riguardano diversi aspetti, vi spieghiamo come evitare sanzioni che possono essere salate
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


Gigabyte MO32U24 OLED: il 4K a 240Hz su un pannello OLED ideale per il gaming Gigabyte MO32U24 OLED: il 4K a 240Hz su un panne...
Recensione realme 16 5G: lo smartphone con Selfie Mirror ha una batteria da 6550mAh Recensione realme 16 5G: lo smartphone con Selfi...
Come rispettare tutte le nuove regole per i monopattini elettrici? La guida per non rischiare sanzioni Come rispettare tutte le nuove regole per i mono...
DLSS 4.5: con Dynamic Frame Generation e MFG 6X NVIDIA alza la posta DLSS 4.5: con Dynamic Frame Generation e MFG 6X ...
Plaud NotePin S, il registratore IA si fa indossabile (ma è facile da perdere) Plaud NotePin S, il registratore IA si fa indoss...
Infineon apre il 2 luglio lo Smart Power...
Crimson Desert non si ferma: il gioco di...
Con iOS 27 l'iPhone si ripristina da sol...
Visa porta i pagamenti in ChatGPT: gli a...
OpenAI valuta un 'drastico' taglio dei p...
Il MacBook con display touch si far&agra...
Google promette di restituire più...
Quattro monitor 4K, doppia LAN 2.5G e Wi...
ROG Equalizer, il cavo 'salva-GPU': prim...
Falla critica CVSS 9.8 in Oracle PeopleS...
Microsoft accelera su Edge: aggiornament...
AMD ha corretto un bug da 10.000 dollari...
Vertiv: data center, la corsa dell’IA sp...
Siri non diventerà la tua fidanzata virt...
Prezzi in crescita del 200% e forniture ...
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: 00:46.


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