Torna indietro   Hardware Upgrade Forum > Software > Programmazione

 Hisense 55U7SE: tuttofare e accessibile, il MiniLED per film, sport e gioco
Hisense 55U7SE: tuttofare e accessibile, il MiniLED per film, sport e gioco
MiniLED di fascia media con local dimming a 192 zone, 144 Hz nativi e audio firmato Devialet. La prova strumentale riscontra colori affidabili e gaming reattivo, per un prodotto molto accessibile e convincente. Ma la soundbar aggiuntiva è quasi d'obbligo
Kindle Scribe Colorsoft: riduce le cornici e diventa a colori, ma il prezzo è alto
Kindle Scribe Colorsoft: riduce le cornici e diventa a colori, ma il prezzo è alto
Amazon porta i colori sul suo Kindle da scrittura più grande: schermo Colorsoft a 11 pollici, processore quad-core, penna premium più reattiva e strumenti IA per le note, sono le note salienti. Il salto di prezzo rispetto al modello in bianco e nero si fa sentire, anche se la percezione è quella di trovarsi di fronte a un prodotto di fascia altissima, per veri appassionati
L'IA cambia tutte le regole della sicurezza tra vulnerabilità e sorveglianza. Intervista al CEO di Proofpoint
L'IA cambia tutte le regole della sicurezza tra vulnerabilità e sorveglianza. Intervista al CEO di Proofpoint
Abbiamo intervistato Sumit Dhawan, CEO di Proofpoint, per capire come stia cambiando il mondo della sicurezza con l'avvento dell'intelligenza artificiale e con il ritmo sempre più serrato a cui vengono trovate vulnerabilità nel software. Un problema significativo, che richiederà del tempo per essere risolto (o quantomeno arginato)
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 28-06-2006, 17:57   #1
Lo_Straniero2003i
Member
 
Iscritto dal: Nov 2005
Messaggi: 37
Java metodo EliminaDoppi

Salve gente. Ho questo piccolo problemino..dico piccolo perchè di sicuro lo è. Come faccio a eliminare i numeri che si presentano in un array più di una volta?

public static int[] eliminaDoppi(int [] v) {
int [] nuovo;
nuovo = new int[v.length];
int cont = 0;
for(int i= 0; i<v.length; i++)
for(int j=0; j<v.length; j++)
if(v[i]!=v[j])
nuovo[cont] = v[i];

\\ a questo punto non appena trovo la prima diversità, copio l'elemento; solo che devo terminare il secondo for...come faccio?

Grazie Gente!!!
Lo_Straniero2003i è offline   Rispondi citando il messaggio o parte di esso
Old 28-06-2006, 19:19   #2
franksisca
Senior Member
 
L'Avatar di franksisca
 
Iscritto dal: May 2005
Città: Roma
Messaggi: 7938
ecco a te, dovrebbe funzionare
Codice:
                public static int[] eliminaDoppi(int [] v) {
               boolean flag=true;
                         int [] nuovo;
                           nuovo = new int[v.length];
                             int cont = 0;
                        for(int i= 0; i<v.length; i++) 
                           for(int j=0; j<v.length && flag; j++)
                                 if(v[i]!=v[j]){
                                    nuovo[cont] = v[i];
                                    flag=false;
                             }
__________________
My gaming placement
franksisca è offline   Rispondi citando il messaggio o parte di esso
Old 29-06-2006, 10:31   #3
sottovento
Senior Member
 
L'Avatar di sottovento
 
Iscritto dal: Nov 2005
Città: Texas
Messaggi: 1722
Ciao,
non vorrei prendere fischi per fiaschi, ma mi sembra che entrambi i codici riportati facciano qualcos'altro.
Beh, innanzitutto la variabile cont non viene mai incrementata, poi mi sarei aspettato di ottenere un array in uscita di dimensioni <= di quello in ingresso.

Forse non ho capito bene il problema, guardando il codice sembra che l'elemento attuale nel vettore di input sia copiato nel vettore di output se nel vettore di input c'e' almeno un elemento diverso da quello in oggetto.

High Flying
Sottovento
__________________
In God we trust; all others bring data
sottovento è offline   Rispondi citando il messaggio o parte di esso
Old 29-06-2006, 11:13   #4
franksisca
Senior Member
 
L'Avatar di franksisca
 
Iscritto dal: May 2005
Città: Roma
Messaggi: 7938
Quote:
Originariamente inviato da sottovento
Ciao,
non vorrei prendere fischi per fiaschi, ma mi sembra che entrambi i codici riportati facciano qualcos'altro.
Beh, innanzitutto la variabile cont non viene mai incrementata, poi mi sarei aspettato di ottenere un array in uscita di dimensioni <= di quello in ingresso.

Forse non ho capito bene il problema, guardando il codice sembra che l'elemento attuale nel vettore di input sia copiato nel vettore di output se nel vettore di input c'e' almeno un elemento diverso da quello in oggetto.

High Flying
Sottovento
pensa che io ho messo solo la flag per far uscire dal secondo for, nemmeno mi ero accorto che cont non si aumente
__________________
My gaming placement
franksisca è offline   Rispondi citando il messaggio o parte di esso
Old 29-06-2006, 15:10   #5
Lo_Straniero2003i
Member
 
Iscritto dal: Nov 2005
Messaggi: 37
Buona idea...grazie!!!
Lo_Straniero2003i è offline   Rispondi citando il messaggio o parte di esso
Old 30-06-2006, 03:27   #6
sottovento
Senior Member
 
L'Avatar di sottovento
 
Iscritto dal: Nov 2005
Città: Texas
Messaggi: 1722
Quote:
Originariamente inviato da Lo_Straniero2003i
Buona idea...grazie!!!
Mi permetto di darti un consiglio: definisci prima una funzione
int contaElementi(vect, elem)
che ti ritorna il numero di valori elem trovati nel vettore.

Poi, nel tuo ciclo principale, la richiami e salvi l'elemento se contaElementi() non e' maggiore di uno. Fai un passaggio in piu' ma mi sembra piu' chiaro

High Flying
Sottovento
__________________
In God we trust; all others bring data
sottovento è offline   Rispondi citando il messaggio o parte di esso
Old 21-07-2006, 21:53   #7
Lo_Straniero2003i
Member
 
Iscritto dal: Nov 2005
Messaggi: 37
Salve gente. Dopo un pò di pausa sono ritornato su questo problema che sinceramente non riesco a risolvere. Il metodo eliminaDoppi da me citato mi riesce più difficile di quanto previsto. Non risco a coordinare bene quello che devo fare. Sbatto sempre sul codice sopra senza arrivare mai ad una soluzione. Potreste dirmi come fare per favore?

Grazie.

Alessandro Gioffreda
Lo_Straniero2003i è offline   Rispondi citando il messaggio o parte di esso
Old 21-07-2006, 23:52   #8
Vash1986
Senior Member
 
Iscritto dal: Jan 2004
Messaggi: 388
Codice:
import java.util.HashSet;
import java.util.Set;
import java.util.Iterator;

public class EliminaDoppi
{

	public static void main(String[] args)
	{
		int prova[] = { 1, 4, 5, 2, 4, 5, 2, 2, 1, 6, 8 };
		int prova2[] = eliminaDoppi(prova);
		
		for ( int i = 0; i < prova2.length; i++ )
			System.out.print( prova2[i] + " ");
		
		System.out.println();
		System.exit(0);
	}
	
	public static int[] eliminaDoppi( int vett[] )
	{		
		if ( vett.length < 2 )
			return vett;
		
		Set< Integer > lista = new HashSet();
		for ( int i = 0; i < vett.length; i++ )
			lista.add( new Integer(vett[i]) );
		Iterator< Integer > i = lista.iterator();
		
		/* Il primo hasNext è per forza true per via del controllo fatto a inizio
		 * metodo su vett.length.
		 */
		int res[] = new int[lista.size()];
		for ( int j = 0; i.hasNext(); j++ )
			res[j] = (int)i.next();
		
		return res;
	}
}
Un altro modo è ordinare il vettore interessato in modo da avere gli elementi doppi uno accanto all'altro e poter costruire dunque facilmente un secondo vettore.
Solo che non mi faceva usare il metodo .sort() del vettore, e piuttosto che farmi un algoritmo di ordinamento alle 0:55 di notte ho usato i Set.

Gli hashset sono strutture dati della libreria standard in cui puoi mettere qualsiasi oggetto, ma non duplicato.
__________________

Ultima modifica di Vash1986 : 21-07-2006 alle 23:57.
Vash1986 è offline   Rispondi citando il messaggio o parte di esso
Old 22-07-2006, 00:09   #9
Vash1986
Senior Member
 
Iscritto dal: Jan 2004
Messaggi: 388
Trovato il sort

Codice:
import java.util.Arrays;

public class EliminaDoppi
{

	public static void main(String[] args)
	{
		int prova[] = { 1, 4, 5, 2, 4, 5, 2, 2, 1, 6, 8 };
		int prova2[] = eliminaDoppi(prova);
		
		for ( int i = 0; i < prova2.length; i++ )
			System.out.print( prova2[i] + " ");
		
		System.out.println();
		System.exit(0);
	}
	
	public static int[] eliminaDoppi( int vett[] )
	{		
		if ( vett.length < 2 )
			return vett;
		
		int res[] = new int[vett.length];
		Arrays.sort( vett );
		
		int doppi = 0;
		res[0] = vett[0];
		int j = 1;
		for ( int i = 1; i < vett.length; i++ )
		{
			if ( vett[i] != vett[i-1] )
			{
				res[j] = vett[i];
				++j;
			}
			else
				++doppi;
		}
		
		if ( doppi == 0 )
			return res;
		
		doppi = res.length - doppi;
		
		int res2[] = new int[ doppi ];
		for (int i = 0; i < doppi; i++ )
			res2[i] = res[i];
		
		return res2;
	}
}
__________________
Vash1986 è offline   Rispondi citando il messaggio o parte di esso
Old 22-07-2006, 10:01   #10
Lo_Straniero2003i
Member
 
Iscritto dal: Nov 2005
Messaggi: 37
Perfetto Grazie, il programma funziona. Vorrei però chiederti una cosa (scusa se ti do del tu). Non ho mai incontrato questa struttura:

Arrays.sort( vett );

Sono uno studente universitario che sta al primo anno. Ho visto che togliendolo se inserisco una sequenza di numeri, per esempio:

1,2,1,2,1,2,1,2 e così via mi ristituisce tale sequenza. Quindi questo metodo di libreria toglie le ripetizioni? E posso ommettere "Arrays.sort( vett );" e inserire al suo posto un'altro frammento codice che faccia la stessa cosa vero? Grazie mille.
Lo_Straniero2003i è offline   Rispondi citando il messaggio o parte di esso
Old 22-07-2006, 10:23   #11
Vash1986
Senior Member
 
Iscritto dal: Jan 2004
Messaggi: 388
Quote:
Originariamente inviato da Lo_Straniero2003i
E posso ommettere "Arrays.sort( vett );" e inserire al suo posto un'altro frammento codice che faccia la stessa cosa vero? Grazie mille.
Come ho già detto, è un metodo che ordina il contenuto degli array. Funziona coi tipi primitivi e con gli oggetti che implementano l'interfaccia Comparable.

Così hai tutti i duplicati uno accanto all'altro, ed è facile riconoscerli a quel punto, basta fare un controllo sugli indici adiacenti nell'array.

Al suo posto puoi chiamare un metodo che faccia un bubble sort o un quick sort.
__________________
Vash1986 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


 Hisense 55U7SE: tuttofare e accessibile, il MiniLED per film, sport e gioco Hisense 55U7SE: tuttofare e accessibile, il Min...
Kindle Scribe Colorsoft: riduce le cornici e diventa a colori, ma il prezzo è alto Kindle Scribe Colorsoft: riduce le cornici e div...
L'IA cambia tutte le regole della sicurezza tra vulnerabilità e sorveglianza. Intervista al CEO di Proofpoint L'IA cambia tutte le regole della sicurezza tra ...
L'Europa conta nella tecnologia e può essere autonoma. Cosa si è detto al Nextcloud Summit 2026 L'Europa conta nella tecnologia e può ess...
Dreame X60 Pro Ultra Complete: i bracci si estendono sempre di più Dreame X60 Pro Ultra Complete: i bracci si esten...
La Corte Suprema riapre, in parte, il ca...
Uno sviluppatore ha reso il nuovo Steam ...
Server privati di Minecraft e Call of Du...
NASA, investimento da 600 milioni di dol...
Lenovo presenta i Security Services con ...
L'Italia mette l'IA in produzione: a Mil...
L'hamburger perfetto esiste? A San Franc...
CISA conferma: il bug di Windows Defende...
Hyper Mini LED e 5K: LG UltraGear evo AI...
Il falso bug di Windows 3.1 che costò a ...
GTA 6 ha già conquistato gli uten...
L'UE ha un grosso problema: la sua ident...
I 10 articoli TOP Amazon per l'estate: t...
Lumo 2.0: Proton sfida ChatGPT e Claude ...
OnePlus lancia il suo entry level N6: ba...
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: 12:40.


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