Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Roborock Qrevo Curv 2 Flow: ora lava con un rullo
Roborock Qrevo Curv 2 Flow: ora lava con un rullo
Qrevo Curv 2 Flow è l'ultima novità di casa Roborock per la pulizia di casa: un robot completo, forte di un sistema di lavaggio dei pavimenti basato su rullo che si estende a seguire il profilo delle pareti abbinato ad un potente motore di aspirazione con doppia spazzola laterale
Alpine A290 alla prova: un'auto bella che ti fa innamorare, con qualche limite
Alpine A290 alla prova: un'auto bella che ti fa innamorare, con qualche limite
Abbiamo guidato per diversi giorni la Alpine A290, la prima elettrica del nuovo corso della marca. Non è solo una Renault 5 sotto steroidi, ha una sua identità e vuole farsi guidare
Recensione HONOR Magic 8 Lite: lo smartphone indistruttibile e instancabile
Recensione HONOR Magic 8 Lite: lo smartphone indistruttibile e instancabile
Abbiamo provato a fondo il nuovo Magic 8 Lite di HONOR, e per farlo siamo volati fino a Marrakech , dove abbiamo testato la resistenza di questo smartphone in ogni condizione possibile ed immaginabile. Il risultato? Uno smartphone praticamente indistruttibile e con un'autonomia davvero ottima. Ma c'è molto altro da sapere su Magic 8 Lite, ve lo raccontiamo in questa recensione completa.
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 25-06-2003, 12:37   #1
dino_sauro00
Senior Member
 
L'Avatar di dino_sauro00
 
Iscritto dal: Feb 2003
Città: Thessaloniki
Messaggi: 2214
Java: Eliminare duplicati dall'array...

Ciao raggazzi (e ciao PGI ). Ho questo problema con un programma Java. Allora, ho creato un array con dei numeri casuali e poi ho usato Arrays.sort(array) per mettere i numeri in ordine. Quello che dovrei fare adesso e eliminare i duplicati dall'array controllando se il vicino di un numero e uguale al numero (visto che i numeri sono gia' sortati). Il codice l'ho scritto ed e' il seguente:

import java.util.Arrays;

public class SortArray
{
public static void main (String [] args)
{
int [] array = new int [10];
int arraySize = array.length;

array[0] = 4;
array[1] = 7;
array[2] = 11;
array[3] = 4;
array[4] = 9;
array[5] = 5;
array[6] = 11;
array[7] = 7;
array[8] = 3;
array[9] = 5;

System.out.println ("Array iniziale");
for (int i=0; i<array.length; i++)
System.out.println (array[i]); //array non sortato

Arrays.sort(array); //array sortato
System.out.println ("\nArray ordinato");
for (int i=0; i<array.length; i++)
System.out.println(array[i]);

//qui comincia l'algoritmo che controlla l'array

for (int i=0; i<=arraySize; i++)
{
if (array[i] != array[i+1])
{
//System.out.println (array[i]);
arraySize--;
}
else
{
int pos = i;

for (int x=pos; x<arraySize; x++)
// System.out.println(array[i]);
{
array[x] = array [x+1];
// System.out.println (array[x]);
pos++;
}

arraySize--;
}
}

System.out.print ("\nArray finale");
for (int i=0; i<array.length-arraySize; i++)
System.out.print ("\n" + array[i]);

}
}


Il problema mi si presenta con l'ultimo elemento. Infatti se si lascia l'array cosi' com'e' (con i due 11 finali) funziona, ma se cambio uno dei due 11 in un altro numero piu' grande non funziona dandomi sempre come ultimo elemento l'11. Ho provato anche a cambiare nell'ultimo for
il i<array.length-arraySize e farlo i<=array.length-arraySize che poi funziona con ultimi elementi un 11 e un 12 ma non funziona con due 11. Infatti in questo caso mi stampa pure anche il secondo 11.
Mi spiace per la lunga spiegazione ma e' un problema un po' bastardo.

Grazie a chi rispondera' riguardo a questo problema ma anche a chi mi da qualche dritta per migliorare il mio modo pessimo di programmare.
Ciaoooo
dino_sauro00 è offline   Rispondi citando il messaggio o parte di esso
Old 25-06-2003, 13:23   #2
kingv
Senior Member
 
L'Avatar di kingv
 
Iscritto dal: Jan 2001
Città: Milano
Messaggi: 5707
lascio a chi ha piu' buona volontà la lettura del tuo codice, volevo solo farti notare che nel package java.util, oltre agli oggetto che implementano l'interfaccia List ci sono quelli che implementano Set che hanno la caratteristica di non permettere duplicati
kingv è offline   Rispondi citando il messaggio o parte di esso
Old 25-06-2003, 14:02   #3
cn73
Senior Member
 
L'Avatar di cn73
 
Iscritto dal: Jul 1999
Città: Torino
Messaggi: 2221
COsa intendi per eliminare l'array?? Come una qualunque variable, bisogna accorgersi quando non serve più e farlo puntare a null.

array = null;

In questo modo il GarbageCollector può ripulire la zona di memoria contenente gli elementi dell'array. Fino a che c'è un riferimento ad essa, tale zona non verrà ripulita.
cn73 è offline   Rispondi citando il messaggio o parte di esso
Old 25-06-2003, 14:20   #4
recoil
Senior Member
 
L'Avatar di recoil
 
Iscritto dal: Jul 2002
Città: Milano
Messaggi: 19149
forse non sarebbe male implementare un algoritmo di ordinamento che elimini da subito i duplicati.
non so però se si tratta di una cosa molto semplice...
recoil è offline   Rispondi citando il messaggio o parte di esso
Old 25-06-2003, 14:22   #5
PGI
Bannato
 
L'Avatar di PGI
 
Iscritto dal: Nov 2001
Città: Verona
Messaggi: 1086
Versione corta.

Ci sono due cose che non vanno in quel programma.

La prima è che diminuisci le dimensioni dell'"array" finale sia che incontri due numeri diversi sia che siano uguali. Il che significa che stampi sempre e comunque metà dell'array (ecco perchè quando cambi il ciclo di stampa da
< a <= stampa sempre un numero in più, sia 11 che 12).

Quindi nel primo if(diversi) va tolto quell'"arraySize--".

Il secondo è un equivoco:

in un ciclo "for" la base (int x=pos) viene calcolata solo all'inizio, poi "pos" non viene più considerato. "pos++" non ha alcun effetto.

La versione "funzionante" è

per il primo if:
Codice:
if (array[i] != array[i+1])
{
//niente, questo if si può anche eliminare
}
per il secondo:

Codice:
else
{
int pos = i;
arraySize--;
for (int x=pos; x<arraySize; x++)
{
array[x] = array [x+1];
//pos++;
}
}
("arraySize--" è stato spostato dal fondo in cima)

A questo punto puoi togliere il primo if ed eliminare "int pos=i" sostituendo semplicemente pos con i.

Ciao.

PS: aggiungo per chiarezza il codice completo modificato come sopra

Codice:
import java.util.Arrays;

public class SortArray 
{
public static void main (String [] args)
{
int [] array = new int [10];
int arraySize = array.length;

array[0] = 4;
array[1] = 7;
array[2] = 11;
array[3] = 4;
array[4] = 9;
array[5] = 5;
array[6] = 11;
array[7] = 7;
array[8] = 3;
array[9] = 5;

System.out.println ("Array iniziale");
for (int i=0; i<array.length; i++)
System.out.println (array[i]); //array non sortato

Arrays.sort(array); //array sortato
System.out.println ("\nArray ordinato");
for (int i=0; i<array.length; i++)
System.out.println(array[i]);

//qui comincia l'algoritmo che controlla l'array

for (int i=0; i<=arraySize; i++)
{
if (array[i] != array[i+1])
{
//System.out.println (array[i]);
//arraySize--;
}
else
{
int pos = i;
arraySize--;
//System.out.println("Size: "+arraySize);
for (int x=pos; x<arraySize; x++)
// System.out.println(array[i]);
{
array[x] = array [x+1];
// System.out.println (array[x]);
//pos++;
}

}
}

System.out.print ("\nArray finale");
for (int i=0; i<=arraySize; i++)
System.out.print ("\n" + array[i]);

}
}
PGI è offline   Rispondi citando il messaggio o parte di esso
Old 25-06-2003, 21:21   #6
dino_sauro00
Senior Member
 
L'Avatar di dino_sauro00
 
Iscritto dal: Feb 2003
Città: Thessaloniki
Messaggi: 2214
FUNZIONA!!!
Ragazzi vi voglio ringraziare tutti quanti per aver avuto la pazienza ad aiutarmi. Un grazie davvero grandissimo a PGI (sei bravissimo nonche una persona davvero disponibilissima. E' un piacere trovare delle persone cosi' che pur essendo di livello avanzato aiutano sempre noi novellini). Ti ringrazio di tutte le spiegazioni e della tua disponibilita'
dino_sauro00 è offline   Rispondi citando il messaggio o parte di esso
Old 25-06-2003, 21:40   #7
PGI
Bannato
 
L'Avatar di PGI
 
Iscritto dal: Nov 2001
Città: Verona
Messaggi: 1086
Ohè, mi fai sentire il "Papa buono" della programmazione!
Fa piacere essere utili.

Ciao.
PGI è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Roborock Qrevo Curv 2 Flow: ora lava con un rullo Roborock Qrevo Curv 2 Flow: ora lava con un rull...
Alpine A290 alla prova: un'auto bella che ti fa innamorare, con qualche limite Alpine A290 alla prova: un'auto bella che ti fa ...
Recensione HONOR Magic 8 Lite: lo smartphone indistruttibile e instancabile Recensione HONOR Magic 8 Lite: lo smartphone ind...
Sony WF-1000X M6: le cuffie in-ear di riferimento migliorano ancora Sony WF-1000X M6: le cuffie in-ear di riferiment...
Snowflake porta l'IA dove sono i dati, anche grazie a un accordo con OpenAI Snowflake porta l'IA dove sono i dati, anche gra...
Samsung integra Perplexity AI in Galaxy ...
'Una telefonata allunga la vita': lo spo...
Gli smart ring di Oura conquistano Washi...
Windows 10 ESU: Microsoft annuncia l'est...
Game Boy LEGO a 45€: il mito Nintendo an...
Andrea Pignataro supera Giovanni Ferrero...
La Cina vieta i volanti a cloche (yoke) ...
Come dovrebbe essere Task Manager second...
Perché HONOR Magic 8 Lite è...
A soli 149€ Roborock Q7 M5 con 10.000 Pa...
Google Pixel 10 a 563€: Android puro e t...
Altman frena sui datacenter AI orbitali:...
Addio RAM cinese a basso costo: 32 GB DD...
Jony Ive e OpenAI preparano uno smart sp...
Altman difende l'efficienza energetica d...
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: 11:40.


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