Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Microsoft Surface Pro 12 è il 2 in 1 più compatto e silenzioso
Microsoft Surface Pro 12 è il 2 in 1 più compatto e silenzioso
Basato su piattaforma Qualcomm Snapdragon X Plus a 8 core, il nuovo Microsoft Surface Pro 12 è un notebook 2 in 1 molto compatto che punta sulla facilità di trasporto, sulla flessibilità d'uso nelle differenti configurazioni, sul funzionamento senza ventola e sull'ampia autonomia lontano dalla presa di corrente
Recensione REDMAGIC Astra Gaming Tablet: che spettacolo di tablet!
Recensione REDMAGIC Astra Gaming Tablet: che spettacolo di tablet!
Il REDMAGIC Astra Gaming Tablet rappresenta una rivoluzione nel gaming portatile, combinando un display OLED da 9,06 pollici a 165Hz con il potente Snapdragon 8 Elite e un innovativo sistema di raffreddamento Liquid Metal 2.0 in un form factor compatto da 370 grammi. Si posiziona come il tablet gaming più completo della categoria, offrendo un'esperienza di gioco senza compromessi in mobilità.
Dopo un mese, e 50 foto, cosa abbiamo capito della nuova Nintendo Switch 2
Dopo un mese, e 50 foto, cosa abbiamo capito della nuova Nintendo Switch 2
Dopo un mese di utilizzo intensivo e l'analisi di oltre 50 scatti, l'articolo offre una panoramica approfondita di Nintendo Switch 2. Vengono esaminate le caratteristiche che la definiscono, con un focus sulle nuove funzionalità e un riepilogo dettagliato delle specifiche tecniche che ne determinano le prestazioni
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 25-01-2010, 13:55   #1
Snakethesniper
Member
 
L'Avatar di Snakethesniper
 
Iscritto dal: Jun 2008
Città: Milano
Messaggi: 90
[Java] Interfaccia Map

Devo creare un programma che visualizzi l'occorrenza delle parole inserite, per farlo devo utilizzare l'interfaccia Map, ma non capisco bene come funziona. Per poterla utilizzare devo utilizzare una delle classi concrete che la implementi.
Il codice che ho scritto è:
Codice:
import java.lang.*;
import java.io.*;
import java.util.*;

public class Soluzione5{
	public static void main(String[] args) throws IOException{
	BufferedReader in = new BufferedReader(new InputStreamReader(System.in));
	HashMap map = new HashMap();
	String input;
	String[] nomi = new String[21];
	int i=0;
	while((input=in.readLine()) != null){
		nomi[i]=input;
		i++;
		}
	String[] nomie = new String[i];
	for(int j=0;j<i;j++){
		nomie[i]=nomi[i];
		}
	Arrays.sort(nomie);
	int j=0;
	int c=0;
	int k;
	while(j<i){
		for(k=j+1;k<i;k++){
			if(nomie[i].equals(nomie[j])){
				c+=1;
				}
			j=c;
			}
		map.put(nomie[i],c);
		}
	}
	}
Solo che in fase di compilazione mi segnala un warning sul map.put(nomie[i],c). Qualcuno sa aiutarmi?

Ultima modifica di Snakethesniper : 25-01-2010 alle 16:06.
Snakethesniper è offline   Rispondi citando il messaggio o parte di esso
Old 26-01-2010, 09:57   #2
banryu79
Senior Member
 
L'Avatar di banryu79
 
Iscritto dal: Oct 2007
Città: Padova
Messaggi: 4131
E' un warning perchè stai usando Map come "raw type" invece di parametrizarlo con un tipo.
Se guardi nei javadoc la definiizione di Map vedrai che essa e' una classe parametrica del tipo: Map<K,V> dove quel K e V sono dei parametri che indicano rispettivamente il tipo di "chiave" e il tipo di "valore" contenuti nella mappa.

Posto che il modo in cui stai usando la mappa va benissimo anche così (usare i Generics non è obbligatorio), puoi specificare i tipi della tua mappa in questo modo:
Codice:
Map<String,Integer> map = new HashMap<String,Integer>();
Dato che la usi così:
Codice:
...
map.put(nomie[counter], c);
dove nomie[counter] è una String e 'c' è un int (ed essendo int un tipo primitivo e non un tipo reference non può essere infilato in una Map, quindi viene wrappato in un Integer).

Ancora una cosa che ho notato, questo pezzo di codice:
Codice:
...
String[] nomie = new String[i];
for(int j=0;j<i;j++){
    nomie[i]=nomi[i];
}
Arrays.sort(nomie);
...
Visto che già hai importato la classe java.util.Arrays per il sorting, perchè non sfruttarla anche per copiare l'array?

Potresti incapsulare queste due utilità (copia dell'array e sorting) in un metodo che, appunto, prende in ingresso un array di String e ne restituisce una copia ordinata:
Codice:
private static String[] copyAndSort(String[] nomi)
{
    String[] copy = Arrays.copyOf(nomi, nomi.length);
    Arrays.sort(copy);
    return copy;
}
e quindi sostituire il pezzo di codice con la chiamata al metodo:
Codice:
// crea 'nomie'
String[] nomie = copyAndSort(nomi);
Infine due note:
1) il ciclo che "consuma" il BufferedInput per popolare l'array 'nomi' procede finche' una invocazione di readLine non torna null.
Va bene, ma non quando come sorgente usi System.in perchè non si verificherà mai quel caso (System.in non "arriverà mai alla fine", semplicemente presa in ingresso una stringa, dopo l'ennesimo "invio" dell'utente rimane in attesa di un nuovo input).
Dovresti quindi aggiungere un controllo per terminare l'inserimento delle stringhe basato sul numero di stringhe inserite, pena un ArrayIndexOutOfBoundsException.
Oppure potresti leggere l'input da un file di testo.

2) il Sorting delle String viene fatto ordinando le String in maniera lessicografica, e l'odine finale forse non e' quello che ti aspetteresti, dato che, ad esempio, tutte le lettere maiuscole "vengono prima" di tutte le lettere minuscole nella tabella ascii.
Cioè risulterebbe che la stringa "Cane" verrebbe prima della stringa "ape", per esempio. Nel package java.text trovi una classe Collator che torna utile nel gestire questi aspetti e altri (anche più raffinati, tipo la gestione delle differenze dovute agli accenti, in modo specifico per un dato linguaggio naturale, ad esempio per quello Polacco), se mai ti servisse.

In alternativa, potresti prendere l'array di stringhe in input e renderle tutte lowercase o tutte uppercase, giusto per ovviare al problema delle maiuscole/minuscole (prima di "farlo a mano" ovviamente controlla se per caso non esiste qualche classe che già lo fa )
__________________

As long as you are basically literate in programming, you should be able to express any logical relationship you understand.
If you don’t understand a logical relationship, you can use the attempt to program it as a means to learn about it.
(Chris Crawford)

Ultima modifica di banryu79 : 26-01-2010 alle 10:04.
banryu79 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Microsoft Surface Pro 12 è il 2 in 1 più compatto e silenzioso Microsoft Surface Pro 12 è il 2 in 1 pi&u...
Recensione REDMAGIC Astra Gaming Tablet: che spettacolo di tablet! Recensione REDMAGIC Astra Gaming Tablet: che spe...
Dopo un mese, e 50 foto, cosa abbiamo capito della nuova Nintendo Switch 2 Dopo un mese, e 50 foto, cosa abbiamo capito del...
Gigabyte Aero X16 Copilot+ PC: tanta potenza non solo per l'IA Gigabyte Aero X16 Copilot+ PC: tanta potenza non...
vivo X200 FE: il top di gamma si è fatto tascabile? vivo X200 FE: il top di gamma si è fatto ...
2 minuti: il tempo per scorrere le 25 of...
Mini LED TCL: confronto tra le migliori ...
Robot aspirapolvere: questi sono i più a...
Portatile tuttofare Lenovo Core i5/16GB ...
Scende a 99€ il tablet 11" 2,4K con...
Amiga: quali erano i 10 giochi più belli
Driver più sicuri: Microsoft alza...
Ego Power+ ha la giusta accoppiata per l...
Scompiglio nei listini Amazon: prezzi im...
Sotto i 105€ il robot Lefant che lava, a...
Mini proiettori smart in offerta: uno co...
Smartwatch Amazfit in offerta: Balance o...
Windows XP ritorna: ecco come usarlo sub...
Arrow Lake in saldo: Intel taglia i prez...
LG C4 da 55'' a 899€ è il top per...
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: 23:52.


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