Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Snowflake porta l'IA dove sono i dati, anche grazie a un accordo con OpenAI
Snowflake porta l'IA dove sono i dati, anche grazie a un accordo con OpenAI
Snowflake ha presentato diverse novità per la sua piattaforma legate all'intelligenza artificiale. Quella forse più eclatante è una collaborazione con OpenAI, ma non mancano diverse nuove funzionalità che rendono la piattaforma più flessibile e in grado di rispondere meglio alle esigenze in continuo cambiamento delle aziende
Sistema Mesh Roamii BE Pro: il Wi-Fi 7 secondo MSI
Sistema Mesh Roamii BE Pro: il Wi-Fi 7 secondo MSI
Con velocità teoriche fino a 11 Gbps, gestione tramite app intelligente e protezione avanzata dei dispositivi, Roamii BE Pro porta il Wi‑Fi 7 tri‑band nelle abitazioni più esigenti. Un sistema Wi-Fi Mesh proposto da MSI allo scopo di garantire agli utenti una rete fluida e continua capace di sostenere streaming 8K, gaming competitivo e le applicazioni moderne più esigenti in termini di banda
Recensione HUAWEI Mate X7: un foldable ottimo, ma restano i soliti problemi
Recensione HUAWEI Mate X7: un foldable ottimo, ma restano i soliti problemi
Mate X7 rinnova la sfida nel segmento dei pieghevoli premium puntando su un design ancora più sottile e resistente, unito al ritorno dei processori proprietari della serie Kirin. L'assenza dei servizi Google e del 5G pesa ancora sull'esperienza utente, ma il comparto fotografico e la qualità costruttiva cercano di compensare queste mancanze strutturali con soluzioni ingegneristiche di altissimo livello
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 17-03-2006, 18:15   #1
tagibo
Junior Member
 
Iscritto dal: Nov 2005
Messaggi: 17
[JAVA] Da HashMap a TreeMap

Nuovo esercizio
Dopo aver riempito la HashMap (vedi post QUI) , mi ritrovo con questa HashMap composta da coppie (frequenza, parola), cioè la frequenza in cui una parola appare in un file .txt.

Ora io dovrei formare delle nuove coppie (x,y) da stampare su file, cioè dove x parole compaiono esattamente y volte.
Devo scrivere un metodo

Codice:
Iterator count(Iterator it)
che riceve un iteratore sui valori della Map h e rende un iteratore sull’ entrySet() di una nuova Map, una TreeMap, che contiene le coppie (x, y).

Allora, io ho scritto questo codice:

Codice:
public static Map m=new HashMap(500);
.....
public static Iterator count(Iterator itr) {
     Map tree=new TreeMap();
     while (itr.hasNext()) {
         Object k = itr.next();
         if (!tree.containsValue(m.get(k))) tree.put(new Integer(1),m.get(k));
         else {
              int val=Integer.parseInt((tree.get(k)).toString());
    	      tree.put(new Integer(val+1),m.get(k));
    	 }
      } 
      Set s=tree.entrySet();
      Iterator i = s.iterator();
      return i;
}
Il porblema è che mi dà una ClassCastException sull'istruzione in neretto.
Esattamente è questo il responso:

Quote:
java.lang.ClassCastException: java.lang.Integer
at java.lang.String.compareTo(Unknown Source)
at java.util.TreeMap.compare(Unknown Source)
at java.util.TreeMap.getEntry(Unknown Source)
at java.util.TreeMap.get(Unknown Source)
at metodi.count(metodi.java:148)
at metodi.index(metodi.java:88)
at metodi.main(metodi.java:48)
Exception in thread "main"
Non so proprio cosa fare, è da un po' che ci sto ragionando ma non vengo mai a capo di questo problema.
Qualcuno mi dà una mano?

thks
tagibo è offline   Rispondi citando il messaggio o parte di esso
Old 17-03-2006, 18:23   #2
franksisca
Senior Member
 
L'Avatar di franksisca
 
Iscritto dal: May 2005
Città: Roma
Messaggi: 7938
mentre ci enso, hai provato senza il toString()?????
e poi, hai provato a fare il cast a stringa di quella cosa lì......
__________________
My gaming placement
franksisca è offline   Rispondi citando il messaggio o parte di esso
Old 17-03-2006, 20:29   #3
tagibo
Junior Member
 
Iscritto dal: Nov 2005
Messaggi: 17
Exception in thread "main" java.lang.ClassCastException
at java.lang.String.compareTo(String.java:797)
at java.util.TreeMap.compare(TreeMap.java:1081)
at java.util.TreeMap.getEntry(TreeMap.java:341)
at java.util.TreeMap.get(TreeMap.java:260)
at Copia_di_metodi.count(Copia_di_metodi.java:148)
at Copia_di_metodi.index(Copia_di_metodi.java:88)
at Copia_di_metodi.main(Copia_di_metodi.java:48)
Press any key to continue...

tagibo è offline   Rispondi citando il messaggio o parte di esso
Old 17-03-2006, 21:16   #4
franksisca
Senior Member
 
L'Avatar di franksisca
 
Iscritto dal: May 2005
Città: Roma
Messaggi: 7938
Quote:
Originariamente inviato da tagibo
Exception in thread "main" java.lang.ClassCastException
at java.lang.String.compareTo(String.java:797)
at java.util.TreeMap.compare(TreeMap.java:1081)
at java.util.TreeMap.getEntry(TreeMap.java:341)
at java.util.TreeMap.get(TreeMap.java:260)
at Copia_di_metodi.count(Copia_di_metodi.java:148)
at Copia_di_metodi.index(Copia_di_metodi.java:88)
at Copia_di_metodi.main(Copia_di_metodi.java:48)
Press any key to continue...

sorry, ma quale caso, cast a stringa o senza toString
__________________
My gaming placement
franksisca è offline   Rispondi citando il messaggio o parte di esso
Old 17-03-2006, 21:21   #5
franksisca
Senior Member
 
L'Avatar di franksisca
 
Iscritto dal: May 2005
Città: Roma
Messaggi: 7938
scusa, mi fai un riassunto della classe che inserisce nella map please.
__________________
My gaming placement
franksisca è offline   Rispondi citando il messaggio o parte di esso
Old 17-03-2006, 21:34   #6
tagibo
Junior Member
 
Iscritto dal: Nov 2005
Messaggi: 17
Quote:
Originariamente inviato da franksisca
sorry, ma quale caso, cast a stringa o senza toString
Ho provato entambi i casi, ma non ne va uno ..... Ti ho postato quello del cast....
Quote:
Originariamente inviato da franksisca
scusa, mi fai un riassunto della classe che inserisce nella map please.
Cmq la classe dell'inserimento nell'hash dovrebbe essere corrtta, il suo lavoro lo fa benissimo!! Eccola qui:
Codice:
public static void addHash(Map map, StringTokenizer s) {
	String str = "";
        //ciclo su s per aggiungere parole alla tabella hash
	while (s.hasMoreTokens()) {
		str = s.nextToken();
		//converto tutte le parole in minuscolo per non avere problemi 
		//con i codici hash
		str = str.toLowerCase();
		if (!map.containsKey(str)) map.put(str,new Integer(1)); //aggiungo
		else { //incremento
			Integer i = (Integer) map.get(str);
			map.put(str,new Integer(i.intValue() + 1));
		}
	}
	System.out.println(map.toString());
}
Ciao!
tagibo è offline   Rispondi citando il messaggio o parte di esso
Old 17-03-2006, 21:38   #7
pinok
Senior Member
 
Iscritto dal: Jun 2001
Città: Alessandria (provincia)
Messaggi: 4772
Se non ho capito male, tiri fuori oggetti di tipo Integer.
Sbagli la conversione, o comunque è arzigogolata

Invece di

int val=Integer.parseInt((tree.get(k)).toString());

prova

int val=( (Integer) tree.get(k) ).intValue();
pinok è offline   Rispondi citando il messaggio o parte di esso
Old 17-03-2006, 21:50   #8
franksisca
Senior Member
 
L'Avatar di franksisca
 
Iscritto dal: May 2005
Città: Roma
Messaggi: 7938
Quote:
Originariamente inviato da pinok
Se non ho capito male, tiri fuori oggetti di tipo Integer.
Sbagli la conversione, o comunque è arzigogolata

Invece di

int val=Integer.parseInt((tree.get(k)).toString());

prova

int val=( (Integer) tree.get(k) ).intValue();
arguto....... effettivamente non ci avevo pensato.......
__________________
My gaming placement
franksisca è offline   Rispondi citando il messaggio o parte di esso
Old 17-03-2006, 22:11   #9
tagibo
Junior Member
 
Iscritto dal: Nov 2005
Messaggi: 17
Quote:
Originariamente inviato da pinok
Se non ho capito male, tiri fuori oggetti di tipo Integer.
Sbagli la conversione, o comunque è arzigogolata

Invece di

int val=Integer.parseInt((tree.get(k)).toString());

prova

int val=( (Integer) tree.get(k) ).intValue();
Exception in thread "main" java.lang.ClassCastException
at java.lang.String.compareTo(String.java:797)
at java.util.TreeMap.compare(TreeMap.java:1081)
at java.util.TreeMap.getEntry(TreeMap.java:341)
at java.util.TreeMap.get(TreeMap.java:260)
at metodi.count(metodi.java:148)
at metodi.index(metodi.java:88)
at metodi.main(metodi.java:48)
Press any key to continue...

Non è possibile!!!
Non ne va bene una, sarà la quindicesima...
tagibo è offline   Rispondi citando il messaggio o parte di esso
Old 17-03-2006, 22:22   #10
PGI-Bis
Senior Member
 
L'Avatar di PGI-Bis
 
Iscritto dal: Nov 2004
Città: Tra Verona e Mantova
Messaggi: 4553
L'istruzione che genera l'eccezione è:

tree.get(k)

Stando alla traccia, il tuo "k" risulta essere un tipo String mentre le chiavi del TreeMap sono di tipo Integer.

Ciao.

Ultima modifica di PGI-Bis : 17-03-2006 alle 22:38. Motivo: c'era una z di troppo in eccezione
PGI-Bis è offline   Rispondi citando il messaggio o parte di esso
Old 17-03-2006, 22:46   #11
tagibo
Junior Member
 
Iscritto dal: Nov 2005
Messaggi: 17
Quote:
Originariamente inviato da PGI-Bis
L'istruzione che genera l'eccezione è:

tree.get(k)

Stando alla traccia, il tuo "k" risulta essere un tipo String mentre le chiavi del TreeMap sono di tipo Integer.

Ciao.
Quindi cosa dovrei fare???
Ormai non ci capisco + nulla, scusami ma ho il cervello "in pappa"......
questo c***o di programma sta mettendo a dura prova la mia pazienza.....
tagibo è offline   Rispondi citando il messaggio o parte di esso
Old 17-03-2006, 22:59   #12
PGI-Bis
Senior Member
 
L'Avatar di PGI-Bis
 
Iscritto dal: Nov 2004
Città: Tra Verona e Mantova
Messaggi: 4553
Cancella tutto e, carta e penna alla mano (virtuali), scrivi la "prosa" di quello che vuoi fare. Quando la prosa è logicamente ineccepibile, la traduci in codice. Se la traduzione è esatta, il programma funzionerà.

Per ogni parola nel testo, sai quante volte quella parola compaia nel testo e devi stabilire quante parole appaiano 1 volta, se ce ne siano, 2 volte, se ce ne siano, 3 volte... n volte.

Ho inteso correttamente?
PGI-Bis è offline   Rispondi citando il messaggio o parte di esso
Old 17-03-2006, 23:04   #13
franksisca
Senior Member
 
L'Avatar di franksisca
 
Iscritto dal: May 2005
Città: Roma
Messaggi: 7938
scusa, ma equals e compareTo della classe che utti, li hai dfatti???
il get delle map riceve un object, quindi fa la ricerca nella lista in base a quei metodi. quindi, vedi tu e poi facci saere.
__________________
My gaming placement
franksisca è offline   Rispondi citando il messaggio o parte di esso
Old 17-03-2006, 23:16   #14
PGI-Bis
Senior Member
 
L'Avatar di PGI-Bis
 
Iscritto dal: Nov 2004
Città: Tra Verona e Mantova
Messaggi: 4553
Stando a quanto detto, mi pare di capire che i dati trattati siano String e Integer. Entrambi sono Comparable, ma, per sintetizzare con la sintassi di Java 5, uno è "Comparable<String>" e l'altro è "Comparable<Integer>", sebbene la vecchia versione di Java non consentisse di esprimerlo durante la compilazione (da cui il ClassCastException).

Un TreeMap che usi l'ordine naturale degli elementi (cioè le cui chiavi siano Comparable) richiede in estrazione un "compareTo" all'argomento del metodo get invocato.

Se k è String, allora è come se si invocasse

[String] compareTo [Integer]

da cui il segnale:

ClassCastException
java.lang.String.compareTo

Non è un problema di mancanza di metodi di comparazione ma di comparazione tra elementi incompatibili che deriva da una svista nella traduzione dal ragionamento che ha fatto tagibo dopo aver capito come si sarebbe potuto fare.

La scelta dell'uso dell'ordine naturale è perfettamente lecita e anche sensata se i dati siano, come sono, interi e stringhe.
PGI-Bis è offline   Rispondi citando il messaggio o parte di esso
Old 18-03-2006, 00:25   #15
franksisca
Senior Member
 
L'Avatar di franksisca
 
Iscritto dal: May 2005
Città: Roma
Messaggi: 7938
Quote:
Originariamente inviato da PGI-Bis
Stando a quanto detto, mi pare di capire che i dati trattati siano String e Integer. Entrambi sono Comparable, ma, per sintetizzare con la sintassi di Java 5, uno è "Comparable<String>" e l'altro è "Comparable<Integer>", sebbene la vecchia versione di Java non consentisse di esprimerlo durante la compilazione (da cui il ClassCastException).

Un TreeMap che usi l'ordine naturale degli elementi (cioè le cui chiavi siano Comparable) richiede in estrazione un "compareTo" all'argomento del metodo get invocato.

Se k è String, allora è come se si invocasse

[String] compareTo [Integer]

da cui il segnale:

ClassCastException
java.lang.String.compareTo

Non è un problema di mancanza di metodi di comparazione ma di comparazione tra elementi incompatibili che deriva da una svista nella traduzione dal ragionamento che ha fatto tagibo dopo aver capito come si sarebbe potuto fare.

La scelta dell'uso dell'ordine naturale è perfettamente lecita e anche sensata se i dati siano, come sono, interi e stringhe.
quello che intendevo io, ma siccome ho sempre preso 2 in italiano..........
__________________
My gaming placement
franksisca è offline   Rispondi citando il messaggio o parte di esso
Old 18-03-2006, 04:26   #16
pinok
Senior Member
 
Iscritto dal: Jun 2001
Città: Alessandria (provincia)
Messaggi: 4772
Io proverei a fare subito il cast dell'oggetto k quando lo tiri fuori, personalmente non mi piace molto girare con oggetti "indefiniti" quando posso farne a meno

Riguardando il codice e se l'ho capito bene, è cannato
Io ho capito che k è la tua parola e vuoi contare quante volte si ripete.
In questo caso dovresti usare k come chiave e come valore il numero di ripetizioni.

Invece tu controlli che non ci sia k come valore (e va bene presumendo che k sia unico per una precedente elaborazione, ma credo sia più lento perché ti perdi l'ottimizzazione sulle chiavi)

tree.containsValue(m.get(k))

e poi scrivi come nuova chiave il numero di ripetizione e ancora k come valore

tree.put(new Integer(val+1),m.get(k));

Ma qua sbagli, infatti stando alla descrizione del metodo:
Associates the specified value with the specified key in this map. If the map previously contained a mapping for this key, the old value is replaced.

In prima approssimazione ti dovresti trovare un tree con un solo elemento, con chiave 1 e valore l'ultima parola, perché tutte le volte che vai a scrivere che hai trovato un'occorrenza di quella parola in realtà aggiorni la chiave 1 con il valore pari alla parola analizzata.
pinok è offline   Rispondi citando il messaggio o parte di esso
Old 19-03-2006, 01:19   #17
tagibo
Junior Member
 
Iscritto dal: Nov 2005
Messaggi: 17
Quote:
Originariamente inviato da pinok
Riguardando il codice e se l'ho capito bene, è cannato
Io ho capito che k è la tua parola e vuoi contare quante volte si ripete.
In questo caso dovresti usare k come chiave e come valore il numero di ripetizioni.
No, io non devo contare la frequenza di una parola, quello l'ho già fatto ed ho inserito tutto nella hashmap. Ora io devo estrarre tutto quello che c'è nella hashmap, fare tutti i controlli del caso e formare delle coppie (x,y) da stampare su file, dove x parole compaiono esattamente y volte.

se ad esempio in un file ho: mah beh mah forse non così non non cioè
l'output sarà: (4,1) (1,2) (1,3), cioè 4 parole appaiono 1 volta, 1 parola appare 2 volte ed 1 parola appare 3 volte.

Grazie delle risposte teoriche a tutti gli altri, ma io ora ho bisogno dell'istruzione corretta. Inutile che mi spiegate qualcosa, perchè nella condizione psicologica in cui sono adesso non capisco nulla!!

Speriamo che quando il programma funzionerà io sia tornato di nuovo "normale", ma ora solo aprire jCreator mi fa venire il mal di testa!!!

Grazie a tutti!!
tagibo è offline   Rispondi citando il messaggio o parte di esso
Old 22-03-2006, 01:59   #18
tagibo
Junior Member
 
Iscritto dal: Nov 2005
Messaggi: 17

GIRA ALLA PERFEZIONE!!!


Risolti tutti i problemi, funziona benissimo. Non ho più pensato al programma Sabato, Domenica e Lunedì; stamattina presto mi ci sono messo per bene, bello sveglio, nel silenzio, e in 20 min. andava tutto ok!! PERFETTO!!
Non chiedetemi cosa ho modificato perchè ero in trance, non mi ricordo nessuna intuizione avuta.... so solo che ora va!!!

Grazie a tutti!!
tagibo è offline   Rispondi citando il messaggio o parte di esso
Old 22-03-2006, 08:31   #19
franksisca
Senior Member
 
L'Avatar di franksisca
 
Iscritto dal: May 2005
Città: Roma
Messaggi: 7938
Quote:
Originariamente inviato da tagibo

GIRA ALLA PERFEZIONE!!!


Risolti tutti i problemi, funziona benissimo. Non ho più pensato al programma Sabato, Domenica e Lunedì; stamattina presto mi ci sono messo per bene, bello sveglio, nel silenzio, e in 20 min. andava tutto ok!! PERFETTO!!
Non chiedetemi cosa ho modificato perchè ero in trance, non mi ricordo nessuna intuizione avuta.... so solo che ora va!!!

Grazie a tutti!!
facci vedere il codice finale, così vedremo tutti la soluzione.
__________________
My gaming placement
franksisca è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


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...
Sistema Mesh Roamii BE Pro: il Wi-Fi 7 secondo MSI Sistema Mesh Roamii BE Pro: il Wi-Fi 7 secondo M...
Recensione HUAWEI Mate X7: un foldable ottimo, ma restano i soliti problemi Recensione HUAWEI Mate X7: un foldable ottimo, m...
Nioh 3: souls-like punitivo e Action RPG Nioh 3: souls-like punitivo e Action RPG
Test in super anteprima di Navimow i220 LiDAR: il robot tagliaerba per tutti Test in super anteprima di Navimow i220 LiDAR: i...
Ford: l'elettrico genera una perdita di ...
Ayaneo Next 2: la console portatile Wind...
Il WiFi può vederti senza telecam...
Linux sotto assedio: SSHStalker riporta ...
Stellantis: dopo il crollo di venerd&igr...
Combat Liquid 360 HUD: raffreddamento AI...
Tornano le EVO Sessions della Formula E:...
Moltbook, il social network per AI: i po...
Cina: eseguito il test della navicella M...
Mistral, il rivale europeo di OpenAI, in...
Libri piratati, allarme rosso: 722 milio...
Ayaneo svela quasi tutte le specifiche d...
Sony chiude definitivamente con i regist...
Renault Twingo E-Tech Electric sotto i 2...
Auto elettriche, il freddo non fa pi&ugr...
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: 21:54.


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