Torna indietro   Hardware Upgrade Forum > Software > Programmazione

PC Specialist Lafité 14 AI AMD: assemblato come vuoi tu
PC Specialist Lafité 14 AI AMD: assemblato come vuoi tu
Il modello "build to order" di PCSpecialist permette di selezionare una struttura base per un sistema, personalizzandolo in base alle specifiche esigenze con una notevole flessibilità di scelta tra i componenti. Il modello Lafité 14 AI AMD è un classico notebook clamshell compatto e potente, capace di assicurare una elevata autonomia di funzionamento anche lontano dalla presa di corrente
Recensione Nothing Phone 4(a): sempre iconico ma ora più concreto
Recensione Nothing Phone 4(a): sempre iconico ma ora più concreto
Nothing con il suo nuovo Phone 4(a) conferma la sua identità visiva puntando su una costruzione che nobilita il policarbonato. La trasparenza resta l'elemento cardine, arricchita da una simmetria interna curata nei minimi dettagli. Il sistema Glyph si evolve, riducendosi nelle dimensioni ma aumentando l'utilità quotidiana grazie a nuove funzioni software integrate e notifiche visive. Ecco tutti i dettagli nella recensione completa
Corsair Vanguard Air 99 Wireless: non si era mai vista una tastiera gaming così professionale
Corsair Vanguard Air 99 Wireless: non si era mai vista una tastiera gaming così professionale
Nelle ultime settimane abbiamo provato la Corsair Vanguard Air 99 Wireless, una tastiera tecnicamente da gaming, ma che in realtà offre un ampio ventaglio di possibilità anche al di fuori delle sessioni di gioco. Flessibilità e funzionalità sono le parole d'ordine di una periferica che si rivolge a chi cerca un prodotto capace di adattarsi a ogni esigenza e ogni piattaforma
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 03-01-2015, 14:54   #1
fedez_
Junior Member
 
Iscritto dal: Jan 2015
Messaggi: 12
[JAVA] Esercizio Array! AIUTOO!

Salve...sto facendo un esercizio sugli array ma non riesco a capire dove sto sbagliando..
Consegna dell'esercizio!

//8. Scrivere un programma C che, dati 2 vettori, ognuno contenente 10 numeri interi positivi inseriti da tastiera, confronti il valore di ciascun elemento del primo con i valori di tutti gli elementi del secondo. Alla fine dovrà stampare a video il numero di elementi uguali e in quale posizione dei vettori questi si trovano.
Esempio:
Inserisco da tastiera i seguenti valori, rispettivamente per i vettori v e w
2 23 43 45 6 76 7 78 76 5
44 4 3 32 2 20 4 5 6 7
Valore Posiz. Vett. v Posiz. Vett. w
2 0 4
6 4 8

Numero di elementi uguali: 4

Codice:
import java.util.Scanner;

public class Tabella {

	public static void main (String[] args) {
	
	Scanner tastiera = new Scanner(System.in);
	
	int k1, w1;
	int w[] = new int [4];
	int k[] = new int [4];
	int tabella[][]= new int [4][3];
	int riga, colonna;
	

	for (w1=0; w1<w.length; w1++)
		w[w1] = tastiera.nextInt();
	System.out.println("Hai completato il primo array!");
	
		
	
	for (k1=0; k1<k.length; k1++)
		k[k1] = tastiera.nextInt();
	System.out.println("Hai completato il secondo array!");
	
	
	for (k1=0; k1<k.length; k1++) {
		for (w1=0; w1<w.length; w1++)
		confronto(k1, w1, k[k1], w[w1], tabella); 
		}	
		
	for (riga=0; riga<4; riga++){
		for (colonna=0; colonna<3; colonna++) {
			System.out.print(tabella[riga][colonna]+"  ");
		}
		System.out.println();
	}
	
	}

	public static void confronto(int n1, int n2, int pos1, int pos2, int [][] tabella) {
		if (n1==n2) {
			int riga = 0;
			valore(n1, riga, tabella, pos1, pos2);
			riga++;
			}
		}
		
	public static void valore (int n1, int riga, int [][] tabella, int pos1, int pos2) {
		tabella[riga][0] = n1;
		posK(pos1, riga, tabella, pos2);
		}
		
	public static void posK (int pos1, int riga, int [][] tabella, int pos2) {
		tabella[riga][1] = pos1;
		posW(pos2, riga, tabella);
		}
		
	public static int [][] posW (int pos2, int riga, int [][] tabella) {
		tabella[riga][2] = pos2;
		return tabella;
		}
		
}
compila ma non funziona correttamente!!!
potete darmi una mano????

Ultima modifica di fedez_ : 03-01-2015 alle 15:22.
fedez_ è offline   Rispondi citando il messaggio o parte di esso
Old 03-01-2015, 17:08   #2
fedez_
Junior Member
 
Iscritto dal: Jan 2015
Messaggi: 12
Ora funziona

Codice:
import java.util.Scanner;

public class Tabella {


    public static void main (String[] args) {
    
    Scanner tastiera = new Scanner(System.in);
    
    int k1, w1;
    int w[] = new int [4];
    int k[] = new int [4];
    int tabella[][]= new int [10][3];
    int riga, colonna;
    riga = 0;


    for (w1=0; w1<w.length; w1++)
        w[w1] = tastiera.nextInt();
    System.out.println("Hai completato il primo array!");
    
        
    
    for (k1=0; k1<k.length; k1++)
        k[k1] = tastiera.nextInt();
    System.out.println("Hai completato il secondo array!");
    
    
    for (w1=0; w1<w.length; w1++) {
        for (k1=0; k1<k.length; k1++)
        confronto(w[w1], k[k1], w1, k1, tabella, riga); 
        riga++;
        }    
        
    String [] intestazione = new String [3];
    intestazione [0] = "Valore";
    intestazione [1] = "Indice (1)";
    intestazione [2] = "Indice (2)";
    for(int i=0; i<3; i++)
        System.out.print(intestazione[i] + "  ");
        System.out.println();
    
    for (riga=0; riga<10; riga++){
        for (colonna=0; colonna<3; colonna++) {
            System.out.print(tabella[riga][colonna]+"           ");
        }
        System.out.println();
    }
    
    }


    public static void confronto(int n1, int n2, int pos1, int pos2, int [][] tabella, int riga) {
        if (n1==n2) {
            valore(n1, riga, tabella, pos1, pos2);
            
            }
        }
        
    public static void valore (int n1, int riga, int [][] tabella, int pos1, int pos2) {
        tabella[riga][0] = n1;
        posK(pos1, riga, tabella, pos2);
        }
        
    public static void posK (int pos1, int riga, int [][] tabella, int pos2) {
        tabella[riga][1] = pos1;
        posW(pos2, riga, tabella);
        }
        
    public static int [][] posW (int pos2, int riga, int [][] tabella) {
        tabella[riga][2] = pos2;
        return tabella;
        }
        
}
l'unica cosa è che non riesco a fare... è creare ogni volta che trova una corrispondenza (n1==n2) una nuova riga per la matrice....
fedez_ è offline   Rispondi citando il messaggio o parte di esso
Old 04-01-2015, 14:37   #3
monte.cristo
Senior Member
 
Iscritto dal: May 2014
Messaggi: 1378
Ho due domande:
1) Se l'assegnamento chiede un programma in C perchè la soluzione è in Java?
2) Non capisco perchè inserire una nuova riga. Nel testo ti viene chiesto solo di inserire da tastiera i valori degli array e poi stampare a video gli indici degli elementi uguali, quindi dovrebbero bastare due cicli for nidificati per confrontare ogni elemento del primo array con tutti quelli del secondo e stampare il valore e gli indici di posizione appena trovi un valore uguale

Ultima modifica di monte.cristo : 04-01-2015 alle 15:02.
monte.cristo è offline   Rispondi citando il messaggio o parte di esso
Old 04-01-2015, 18:02   #4
fedez_
Junior Member
 
Iscritto dal: Jan 2015
Messaggi: 12
Quote:
Originariamente inviato da monte.cristo Guarda i messaggi
Ho due domande:
1) Se l'assegnamento chiede un programma in C perchè la soluzione è in Java?
2) Non capisco perchè inserire una nuova riga. Nel testo ti viene chiesto solo di inserire da tastiera i valori degli array e poi stampare a video gli indici degli elementi uguali, quindi dovrebbero bastare due cicli for nidificati per confrontare ogni elemento del primo array con tutti quelli del secondo e stampare il valore e gli indici di posizione appena trovi un valore uguale
1) ho preso degli esercizi in rete... colpa mia devo farlo in java
2) mmm quindi cosa dovrei fare? io praticamente ho creato un array contenete la richiesta dell'esercizio, ovvero l'ho riempito in base o meno alla coincidenza degli elementi uguali. in questo modo, sarebbe stato molto più utile che non appena venga trovata una coincidenza (n1==n2) mi si crei una riga dell'array, in modo tale da costruirmi l'array man mano. così invece devo, una volta creato, dargli subito delle specifiche dimensioni.
dici che basta ogni qualvolta venga trovato un elemento uguale, stamparlo senza incasellarlo in una matrice?

Ultima modifica di fedez_ : 04-01-2015 alle 18:09.
fedez_ è offline   Rispondi citando il messaggio o parte di esso
Old 04-01-2015, 20:51   #5
monte.cristo
Senior Member
 
Iscritto dal: May 2014
Messaggi: 1378
Visto che è un esercizio, se vuoi metterli in un array per imparare, va bene.
Nel testo dell'esercizio, però, non c'è scritto da nessuna parte che i numeri devono essere salvati in un array. Ti viene chiesto solo di stamparli, quindi per risolvere l'esercizio rispondendo alle richieste scritte, secondo me basta qualcosa del tipo

Codice:
inserisci il primo array
inserisci il secondo array
for (i da 1 fino 10)
  for (j da 1 fino a 10)
    se primovettore[i]=secondovettore[j]
       stampa valore, i, j
Mi sembra che la tua soluzione sia "sovradimensionata" per un problema così semplice. Ad esempio
Codice:
String [] intestazione = new String [3];
    intestazione [0] = "Valore";
    intestazione [1] = "Indice (1)";
    intestazione [2] = "Indice (2)";
    for(int i=0; i<3; i++)
        System.out.print(intestazione[i] + "  ");
        System.out.println();
Per stampare un'intestazione, perchè dichiarare un array di tre elementi? Le tre stringhe non verranno modificate nè usate in altri punti quindi per stampare l'intestazione bastava una semplice istruzione del tipo
System.out.println(" Valore Indice(1) Indice (2)")
Per non parlare, poi, dei metodi dichiarati come confronto e valore, di cui non capisco l'utilità.

Ultima modifica di monte.cristo : 04-01-2015 alle 20:57.
monte.cristo è offline   Rispondi citando il messaggio o parte di esso
Old 05-01-2015, 09:41   #6
fedez_
Junior Member
 
Iscritto dal: Jan 2015
Messaggi: 12
sì sono più che altro esercizi per far pratica e imparare, ecco il perché dei 3 metodi e tutto il resto...
fedez_ è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


PC Specialist Lafité 14 AI AMD: assemblato come vuoi tu PC Specialist Lafité 14 AI AMD: assemblat...
Recensione Nothing Phone 4(a): sempre iconico ma ora più concreto Recensione Nothing Phone 4(a): sempre iconico ma...
Corsair Vanguard Air 99 Wireless: non si era mai vista una tastiera gaming così professionale Corsair Vanguard Air 99 Wireless: non si era mai...
Ecovacs DEEBOT T90 PRO OMNI: ora il rullo di lavaggio è ampio Ecovacs DEEBOT T90 PRO OMNI: ora il rullo di lav...
Recensione Samsung Galaxy S26 Ultra: finalmente qualcosa di nuovo Recensione Samsung Galaxy S26 Ultra: finalmente ...
Elon Musk ha annunciato Terafab: fabbric...
Tutte le migliori offerte Amazon del wee...
Assassin's Creed: iniziate le riprese de...
TV 4K in super offerta: 75'' Mini-LED Hi...
iPad Air in offerta: 11'' con chip M3 a ...
Garmin Instinct 2X Solar Tactical a 259€...
Crimson Desert: Intel ha cercato di coll...
MacBook Air M4 da 899€ su Amazon, ma non...
POCO X8 Pro e Pro Max 12/512GB -23% su A...
Twitter, la verità dietro il crol...
Scivolone ASRock: annuncia il Ryzen 9 99...
DLSS 5: NVIDIA spiega il funzionamento, ...
PlayStation come NVIDIA DLSS: Sony punta...
OnePlus Nord 6 sta arrivando e avr&agrav...
CPU desktop: Intel dice addio ai socket ...
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:53.


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