Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Redmi Note 15 Pro+: autonomia monstre e display luminoso, ma il prezzo è alto
Redmi Note 15 Pro+: autonomia monstre e display luminoso, ma il prezzo è alto
Xiaomi ha portato sul mercato internazionale la nuova serie Redmi Note, che rappresenta spesso una delle migliori scelte per chi non vuole spendere molto. Il modello 15 Pro+ punta tutto su una batteria capiente e su un ampio display luminoso, sacrificando qualcosa in termini di potenza bruta e velocità di ricarica
HONOR Magic 8 Pro: ecco il primo TOP del 2026! La recensione
HONOR Magic 8 Pro: ecco il primo TOP del 2026! La recensione
HONOR ha finalmente lanciato il suo nuovo flagship: Magic 8 Pro. Lo abbiamo provato a fondo in queste settimane e ve lo raccontiamo nella nostra recensione completa. HONOR rimane fedele alle linee della versione precedente, aggiungendo però un nuovo tasto dedicato all'AI. Ma è al suo interno che c'è la vera rivoluzione grazie al nuovo Snapdragon 8 Elite Gen 5 e alla nuova MagicOS 10
Insta360 Link 2 Pro e 2C Pro: le webcam 4K che ti seguono, anche con gimbal integrata
Insta360 Link 2 Pro e 2C Pro: le webcam 4K che ti seguono, anche con gimbal integrata
Le webcam Insta360 Link 2 Pro e Link 2C Pro sono una proposta di fascia alta per chi cerca qualità 4K e tracciamento automatico del soggetto senza ricorrere a configurazioni complesse. Entrambi i modelli condividono sensore, ottiche e funzionalità audio avanzate, differenziandosi per il sistema di tracciamento: gimbal a due assi sul modello Link 2 Pro, soluzione digitale sul 2C Pro
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 15-02-2012, 02:14   #1
guylmaster
Senior Member
 
L'Avatar di guylmaster
 
Iscritto dal: Aug 2002
Messaggi: 2518
[Java] Struttura dati grafi, esistono già?

Qualcuno sa dirmi se come struttura dati in Java esiste già il Grafo e non vedo ricrearmelo tutto da zero?

Perché fino ad ora ho utilizzato più che altro liste o dizionari, ma di grafi è la prima volta che devo utilizzarli in java e volevo capire se potevo evitare di dovermeli creare da zero.

Vi ringrazio in anticipo,
Guylmaster.
guylmaster è offline   Rispondi citando il messaggio o parte di esso
Old 15-02-2012, 09:56   #2
ndakota
Senior Member
 
L'Avatar di ndakota
 
Iscritto dal: Oct 2006
Città: milano
Messaggi: 1439
Ci stavo pensando proprio in questi giorni che mi sembra assurdo non siano previsti nella libreria standard. In ogni caso, non devi riscriverteli da zero, ci sono soluzioni di terze parti molto valide.

http://www.jgrapht.org/
ndakota è offline   Rispondi citando il messaggio o parte di esso
Old 15-02-2012, 12:08   #3
banryu79
Senior Member
 
L'Avatar di banryu79
 
Iscritto dal: Oct 2007
Città: Padova
Messaggi: 4131
JGrapht - per le strutture dati e gli algoritmi
JGraph - per la GUI
(JGrapht supporta l'interoperabilità con JGraph; JGraph può anche essere usata da sola).
__________________

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)
banryu79 è offline   Rispondi citando il messaggio o parte di esso
Old 21-02-2012, 10:47   #4
guylmaster
Senior Member
 
L'Avatar di guylmaster
 
Iscritto dal: Aug 2002
Messaggi: 2518
Rieccomi, ho un piccolo problemino: Di base nei vari demo gli si passa come archi un oggetto defaultedge che non permette di etichettare gli archi.

Io ho bisogno di fare archi etichettati con stringhe, come faccio a creare un tipo mio di arco o a trovarne uno già fatto che permetta di etichettare gli archi?
guylmaster è offline   Rispondi citando il messaggio o parte di esso
Old 21-02-2012, 10:52   #5
banryu79
Senior Member
 
L'Avatar di banryu79
 
Iscritto dal: Oct 2007
Città: Padova
Messaggi: 4131
Quote:
Originariamente inviato da guylmaster Guarda i messaggi
Rieccomi, ho un piccolo problemino: Di base nei vari demo gli si passa come archi un oggetto defaultedge che non permette di etichettare gli archi.

Io ho bisogno di fare archi etichettati con stringhe, come faccio a creare un tipo mio di arco o a trovarne uno già fatto che permetta di etichettare gli archi?
Devi aver mancato questo esempio:
http://sourceforge.net/apps/mediawik...t:LabeledEdges
In pratica definisci una tua classe che estende DefaultEdge e implementi quello che ti pare.
__________________

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 : 21-02-2012 alle 12:57.
banryu79 è offline   Rispondi citando il messaggio o parte di esso
Old 21-02-2012, 11:13   #6
guylmaster
Senior Member
 
L'Avatar di guylmaster
 
Iscritto dal: Aug 2002
Messaggi: 2518
Quote:
Originariamente inviato da banryu79 Guarda i messaggi
Devi aver mancato questo esempio:
http://sourceforge.net/apps/mediawik...t:LabeledEdges
In partica definisci una tua classe che estende DefaultEdge e implementi quello che ti pare.
Ho provato a ricopiare nel package grapht esatto esatto quell'esempio, non da errori e viene eseguito però non stampa nulla, invece dovrebbe stampare le liste di amici e nemici. Cosa mi sfugge?
guylmaster è offline   Rispondi citando il messaggio o parte di esso
Old 21-02-2012, 12:25   #7
banryu79
Senior Member
 
L'Avatar di banryu79
 
Iscritto dal: Oct 2007
Città: Padova
Messaggi: 4131
Quote:
Originariamente inviato da guylmaster Guarda i messaggi
Ho provato a ricopiare nel package grapht esatto esatto quell'esempio, non da errori e viene eseguito però non stampa nulla, invece dovrebbe stampare le liste di amici e nemici. Cosa mi sfugge?
Umm... sì, l'esempio online contiene una piccola "svista", eccone una versione funzionante (correzioni evidenziate):
Codice:
package jgrapht;

import java.util.ArrayList;
import org.jgrapht.DirectedGraph;
import org.jgrapht.graph.ClassBasedEdgeFactory;
import org.jgrapht.graph.DefaultEdge;
import org.jgrapht.graph.DirectedMultigraph;

public class LabeledEdges {
    private static final String friend = "friend";
    private static final String enemy = "enemy";

    public static void main(String[] args) {
        DirectedGraph<String, RelationshipEdge> graph =
            new DirectedMultigraph<String, RelationshipEdge>(
                    new ClassBasedEdgeFactory<String, RelationshipEdge>(RelationshipEdge.class));

        ArrayList<String> people = new ArrayList<String>();
        people.add("John");
        people.add("James");
        people.add("Sarah");
        people.add("Jessica");

        // John is everyone's friend
        for (String person : people) {
            graph.addVertex(person);
            graph.addEdge(people.get(0), person, new RelationshipEdge<String>(people.get(0), person, friend));
        }

        // Apparently James doesn't really like John
        graph.addEdge("James", "John", new RelationshipEdge<String>("James", "John", enemy));

        // Jessica is Sarah and James's friend
        graph.addEdge("Jessica", "Sarah", new RelationshipEdge<String>("Jessica", "Sarah", friend));
        graph.addEdge("Jessica", "James", new RelationshipEdge<String>("Jessica", "James", friend));

        // But Sarah doesn't really like James
        graph.addEdge("Sarah", "James", new RelationshipEdge<String>("Sarah", "James", enemy));

        for (RelationshipEdge edge : graph.edgeSet()) {
            if (edge.hasLabel(enemy)) {
                System.out.printf("%s is an enemy of %s\n", edge.getV1(), edge.getV2());
            } else if (edge.hasLabel(friend)) {
                System.out.printf("%s is a friend of %s\n", edge.getV1(), edge.getV2());
            }
        }
    }

    public static class RelationshipEdge<V> extends DefaultEdge {
        private V v1;
        private V v2;
        private String label;

        public RelationshipEdge(V v1, V v2, String label) {
            this.v1 = v1;
            this.v2 = v2;
            this.label = label;
        }

        public V getV1() {
            return v1;
        }

        public V getV2() {
            return v2;
        }

        public boolean hasLabel(String label) {
            return this.label.equals(label);
        }

        @Override
        public String toString() {
            return label;
        }
    }
}
Dovrebbe produrre in output:
Quote:
run:
John is a friend of John
John is a friend of James
John is a friend of Sarah
John is a friend of Jessica
James is an enemy of John
Jessica is a friend of Sarah
Jessica is a friend of James
Sarah is an enemy of James
BUILD SUCCESSFUL (total time: 0 seconds)
__________________

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)
banryu79 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Redmi Note 15 Pro+: autonomia monstre e display luminoso, ma il prezzo è alto Redmi Note 15 Pro+: autonomia monstre e display ...
HONOR Magic 8 Pro: ecco il primo TOP del 2026! La recensione HONOR Magic 8 Pro: ecco il primo TOP del 2026! L...
Insta360 Link 2 Pro e 2C Pro: le webcam 4K che ti seguono, anche con gimbal integrata Insta360 Link 2 Pro e 2C Pro: le webcam 4K che t...
Motorola edge 70: lo smartphone ultrasottile che non rinuncia a batteria e concretezza Motorola edge 70: lo smartphone ultrasottile che...
Display, mini PC, periferiche e networking: le novità ASUS al CES 2026 Display, mini PC, periferiche e networking: le n...
Il razzo spaziale NASA SLS e la capsula ...
Samsung Galaxy S26 Ultra: quattro colora...
AWS investe 1,2 miliardi in Italia. Coin...
La navicella cinese Shenzhou-20 con il f...
I piani Business ed Education di Google ...
Ceres-2 e Lunga Marcia 3B: la Cina falli...
Motorola edge 70 appena uscito e già in ...
ARC Raiders non si accontenta: nel 2026 ...
Germania, bonus per le auto elettriche d...
Nella causa OpenAI, Elon Musk rivendica...
DJI Osmo 360 in offerta su Amazon: video...
Canada: raggiunto accordo con la Cina, c...
500 terabyte di libri pirata per addestr...
Mandiant le pubblica rainbow table Net-N...
Robot aspirapolvere top di gamma al mini...
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: 16:42.


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