Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Recensione Samsung Galaxy S26 Ultra: finalmente qualcosa di nuovo
Recensione Samsung Galaxy S26 Ultra: finalmente qualcosa di nuovo
Per diversi giorni il Galaxy S26 Ultra di Samsung è stato il nostro compagno di vita. Oltre alle conferme del colosso coreano come la qualità del display e una suite AI senza rivali, arriva il Privacy Display, un unicum nel mondo smartphone. Ci sono ancora alcuni gap che non sono riusciti a colmare lato batteria e fotocamera, seppur con alcuni miglioramenti.
Diablo II Resurrected: il nuovo DLC Reign of the Warlock
Diablo II Resurrected: il nuovo DLC Reign of the Warlock
Abbiamo provato per voi il nuovo DLC lanciato a sorpresa da Blizzard per Diablo II: Resurrected e quella che segue è una disamina dei nuovi contenuti che abbiamo avuto modo di sperimentare nel corso delle nostre sessioni di gioco, con particolare riguardo per la nuova classe dello Stregone
Deep Tech Revolution: così Area Science Park apre i laboratori alle startup
Deep Tech Revolution: così Area Science Park apre i laboratori alle startup
Siamo tornati nel parco tecnologico di Trieste per il kick-off del programma che mette a disposizione di cinque startup le infrastrutture di ricerca, dal sincrotrone Elettra ai laboratori di genomica e HPC. Roberto Pillon racconta il modello e la visione
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 15-11-2007, 16:56   #1
gigippa
Member
 
Iscritto dal: Apr 2007
Città: Torino
Messaggi: 95
[Java] problema con array

Ciao a tutti. Devo implementare un metodo
public static int[] creaVett(int[] a, int[] b)
che riceva in ingresso due array di numeri interi a e b e restituisca un array di interi. L’array di ouput contiene gli elementi che compaiono in a ma non in b, ad es.:
a: 1 | 2 | 3 | 5 | 6 | 5; b: 2 | 6 | 4 output: 1 | 3 | 5 | 5
Io ho provato così ma non mi funziona. chi mi aiuta? grazie
Codice:
public static int[] creaVett(int[] a, int[] b){

		int j = 0;
		int k = 0;
		int[] d = new int[a.length];

		for(int i = 0; i < a.length; i++){
			while(j<b.length){
				if(a[i]!=b[j]){
					d[k]=a[i];
					k++;
				}
				j++;
			}
			}
                return d;
	}
gigippa è offline   Rispondi citando il messaggio o parte di esso
Old 15-11-2007, 17:17   #2
andbin
Senior Member
 
L'Avatar di andbin
 
Iscritto dal: Nov 2005
Città: TO
Messaggi: 5206
Per ogni elemento nell'array 'a' devi scansionare l'array 'b' per vedere se esiste. Se lo trovi sai già subito che non dovrai metterlo nell'array di output. Se non c'è lo sai solo alla fine della scansione di 'b'! Questo vuol dire che solo quando avrai finito di scansionare l'array 'b' allora saprai che l'elemento deve essere inserito nell'array di output.

Il concetto è ben diverso da quello che hai implementato tu.
__________________
Andrea, SCJP 5 (91%) - SCWCD 5 (94%)
andbin è offline   Rispondi citando il messaggio o parte di esso
Old 15-11-2007, 17:41   #3
gigippa
Member
 
Iscritto dal: Apr 2007
Città: Torino
Messaggi: 95
Quote:
Originariamente inviato da andbin Guarda i messaggi
Per ogni elemento nell'array 'a' devi scansionare l'array 'b' per vedere se esiste. Se lo trovi sai già subito che non dovrai metterlo nell'array di output. Se non c'è lo sai solo alla fine della scansione di 'b'! Questo vuol dire che solo quando avrai finito di scansionare l'array 'b' allora saprai che l'elemento deve essere inserito nell'array di output.

Il concetto è ben diverso da quello che hai implementato tu.
Ok... ci lavoro su. Grazie
gigippa è offline   Rispondi citando il messaggio o parte di esso
Old 15-11-2007, 18:01   #4
gigippa
Member
 
Iscritto dal: Apr 2007
Città: Torino
Messaggi: 95
Questa come ti sembra?
Codice:
public static int[] creaVett(int[] a, int[] b){

		int j = 0;
		int k = 0;
		//int i = 0;
		int[] d = new int[a.length];

		for(int i = 0; i < a.length; i++){
        while(j<b.length){
		if(a[i]==b[j]){
			j++;
		}
		else{
			d[k]=a[i];
			k++;
		}
	}
}//for
return d;


	}
Se puoi per favore aiutami ancora
gigippa è offline   Rispondi citando il messaggio o parte di esso
Old 15-11-2007, 18:07   #5
andbin
Senior Member
 
L'Avatar di andbin
 
Iscritto dal: Nov 2005
Città: TO
Messaggi: 5206
Quote:
Originariamente inviato da gigippa Guarda i messaggi
Questa come ti sembra?
A occhio direi che non è ancora corretto. Solo alla fine della scansione (se non hai trovato l'elemento) sai che devi inserire l'elemento nell'array di output.

Se trovi che a[i] != b[j] non vuol dire che devi subito inserire l'elemento. Perché l'elemento successivo in 'b' potrebbe corrispondere.

Per dirla ancora in altri termini: se in 'b' trovi l'elemento, devi terminare subito la scansione di 'b' e sai che non devi inserire l'elemento. Altrimenti devi andare avanti e solo alla fine della scansione di 'b' sai che l'elemento va aggiunto.
__________________
Andrea, SCJP 5 (91%) - SCWCD 5 (94%)
andbin è offline   Rispondi citando il messaggio o parte di esso
Old 15-11-2007, 18:14   #6
gigippa
Member
 
Iscritto dal: Apr 2007
Città: Torino
Messaggi: 95
Quote:
Originariamente inviato da andbin Guarda i messaggi

Per dirla ancora in altri termini: se in 'b' trovi l'elemento, devi terminare subito la scansione di 'b' e sai che non devi inserire l'elemento. Altrimenti devi andare avanti e solo alla fine della scansione di 'b' sai che l'elemento va aggiunto.
Ok. Ma come posso "dirlo" in java?
gigippa è offline   Rispondi citando il messaggio o parte di esso
Old 15-11-2007, 20:34   #7
andbin
Senior Member
 
L'Avatar di andbin
 
Iscritto dal: Nov 2005
Città: TO
Messaggi: 5206
Quote:
Originariamente inviato da gigippa Guarda i messaggi
Ok. Ma come posso "dirlo" in java?
Potresti tenere un "flag". Prima di iniziare il ciclo su 'b' metti questo flag (va bene un boolean, ad esempio) in modo da indicare la condizione di "non trovato". Appena trovi una corrispondenza, setti il flag in modo da indicare la condizione di "trovato" ed esci dal ciclo.
Dopo il ciclo testi il flag e se indica "non trovato", allora aggiungi l'elemento.

Esiste anche una soluzione più furba che evita l'utilizzo di una variabile di flag. Si tratta di sfruttare la istruzione di continue con label (etichetta).
__________________
Andrea, SCJP 5 (91%) - SCWCD 5 (94%)
andbin è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Recensione Samsung Galaxy S26 Ultra: finalmente qualcosa di nuovo Recensione Samsung Galaxy S26 Ultra: finalmente ...
Diablo II Resurrected: il nuovo DLC Reign of the Warlock Diablo II Resurrected: il nuovo DLC Reign of the...
Deep Tech Revolution: così Area Science Park apre i laboratori alle startup Deep Tech Revolution: così Area Science P...
HP OMEN MAX 16 con RTX 5080: potenza da desktop replacement a prezzo competitivo HP OMEN MAX 16 con RTX 5080: potenza da desktop ...
Recensione Google Pixel 10a, si migliora poco ma è sempre un'ottima scelta Recensione Google Pixel 10a, si migliora poco ma...
MacBook Neo sorprende iFixit: 'Non vedev...
Venus Optics presenta due nuovi obiettiv...
AMD pubblica una guida per eseguire Open...
Tomb Raider I-III Remastered arriva su A...
X fa marcia indietro: si adeguerà...
Framework e la crisi delle memorie: terz...
Doom è ovunque: perché il ...
NVIDIA aggiorna G-Sync Pulsar: migliorat...
Portatile gaming con RTX 5060 a 1.099€: ...
6G for dummies: al MWC 2026 il CEO di Qu...
Le RAM tornano a salire di prezzo: quest...
5 robot aspirapolvere bestseller al mini...
A 59 anni il mio primo hackathon: dieci ...
Come sfruttare le Offerte di Primavera p...
NVIDIA promette un salto enorme: path tr...
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: 17:55.


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