Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'' per spingere gli handheld gaming PC al massimo
Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'' per spingere gli handheld gaming PC al massimo
Lenovo Legion Go 2 è la nuova handheld PC gaming con processore AMD Ryzen Z2 Extreme (8 core Zen 5/5c, GPU RDNA 3.5 16 CU) e schermo OLED 8,8" 1920x1200 144Hz. È dotata anche di controller rimovibili TrueStrike con joystick Hall effect e una batteria da 74Wh. Rispetto al dispositivo che l'ha preceduta, migliora ergonomia e prestazioni a basse risoluzioni, ma pesa 920g e costa 1.299€ nella configurazione con 32GB RAM/1TB SSD e Z2 Extreme
AWS re:Invent 2025: inizia l'era dell'AI-as-a-Service con al centro gli agenti
AWS re:Invent 2025: inizia l'era dell'AI-as-a-Service con al centro gli agenti
A re:Invent 2025, AWS mostra un’evoluzione profonda della propria strategia: l’IA diventa una piattaforma di servizi sempre più pronta all’uso, con agenti e modelli preconfigurati che accelerano lo sviluppo, mentre il cloud resta la base imprescindibile per governare dati, complessità e lock-in in uno scenario sempre più orientato all’hybrid cloud
Cos'è la bolla dell'IA e perché se ne parla
Cos'è la bolla dell'IA e perché se ne parla
Si parla molto ultimamente di "bolla dell'intelligenza artificiale", ma non è sempre chiaro perché: l'IA è una tecnologia molto promettente e che ha già cambiato molte cose dentro e fuori le aziende, ma ci sono enormi aspettative che stanno gonfiando a dismisura i valori delle azioni e distorcendo il mercato. Il che, com'è facile intuire, può portare a una ripetizione della "bolla dotcom", e forse anche di quella dei mutui subprime. Vediamo perché
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 14-06-2012, 13:26   #1
Alhazred
Senior Member
 
L'Avatar di Alhazred
 
Iscritto dal: Dec 2003
Messaggi: 1765
[Java] Ricercapercorsi in un multigrafo


Il multigrafo qui sopra rappresenta un'ipotetica rete metropolitana.
Le lettere sono i nomi delle stazioni, i numeri sono i nomi delle linee (bidirezionali).

Date due stazioni qualsiasi, devo trovare tutti i percorsi possibili, scartando quelli che mi fanno usare la stessa linea alternata ad un'altra.
Ad esempio da A a F il percorso
A --(linea 1)--> B --(linea 1)--> C --(linea 2)--> F
è un percorso buono, invece
A --(linea 2)--> B --(linea 1)--> C --(linea 2)--> F
andrebbe scartato

Fin quando si tratta di un grafo semplice (quindi una sola linea tra due stazioni) non ho problemi, ho già scritto il codice e fa tutto quello che deve fare, uso una BFS per trovare i percorsi.

Il problema è che non so come modificare l'algoritmo in modo che controlli tutti i percorsi tenendo in considerazione che si tratta di un multigrafo.

Di seguito riporto la parte che mi fa la ricerca dei percorsi.
Come già detto, in caso di grafo semplice funziona, con un multigrafo no.

Qualcuno saprebbe indicarmi come modificare il codice?
Se necessario posso fornire il codice di tutte e 5 le classi in modo che se volete potete testarlo.

Codice PHP:
public List<Pathbfs(GraphImpl<String,Integerg,
                              
LinkedList<VertexImpl<String>> visited,
                           List<
Pathpaths,
                           
VertexImpl<Stringdestination) {

        
//vertici raggiungibili dal vertice corrente
        
Collection<VertexImpl<String>> nodes g.outVertices(visited.getLast());
        
// esamina i vertici adiacenti
        
for (VertexImpl<Stringnode nodes) {
            if (
visited.contains(node)) { //se il vertice corrente è già stato visitiato
                
continue;
            }

            if (
node.equals(destination)) { //se il vertice corrente è quello di destinazione
                
visited.add(node);

                
boolean buono   true;        //dice se il percorso è buono
                
boolean inarray false;    //dice se una linea è già nell'array

                
Iterator<VertexImpl<String>> li visited.iterator();
                
VertexImpl<Stringv1 null;
                
VertexImpl<Stringv2 null;
                
String lineaTemp "";
                
String[] linee = new String[20];
                for(
int k=0k<20k++) linee[k] = "";
                
int i 0;

                
v1 li.next();
                while(
li.hasNext()) {
                    
v2 li.next(); //vertice di arrivo

                    
EdgeImpl<String,Integeredge g.getEdge(v1,v2); //arco che conginge v1 e v2

                    
if(lineaTemp.equals("")) { //è la prima tratta
                        
lineaTemp edge.getLine();
                        
linee[i]  = edge.getLine();
                        
i++;
                    } else { 
//non è la prima tratta
                        
if(!lineaTemp.equals(edge.getLine())) {         //se la linea attuale è diversa dalla precedente (se c'è stato un cambio di linea)
                               
for(int j=0;j<linee.length;j++) {             //per ogni linea già presa in considerazione
                                   
if(linee[j].equals(edge.getLine())) {     //se una è uguale a quella attuale
                                       
inarray true;                        //indico che è stata trovata
                                   
}
                               }
                               if(!
inarray) { //se la linea corrente non era stata presa in considerazione
                                   
lineaTemp edge.getLine(); //aggiorno l'ultima linea presa in considerazione
                                   
linee[i]  = edge.getLine(); //aggiungo la linea alla lista delle linee
                                   
i++;
                               } else { 
//si è tornati su una linea utilizzata in precedenza per lo stesso percorso, non va bene
                                   
buono false;     //il percorso non è buono
                                   
inarray false//resetto la variabile inarray
                               
}
                        } else { 
//il percorso è buono
                            
buono true;
                            
inarray false;
                        }
                    }

                    
v1 v2;
                }

                if(
buono) { //se il percorso è buono lo aggiungo alla lista dei percorsi
                    //codice omesso per brevità
                
}

                   
visited.removeLast();
                break;
            }
        }

        
//ricorsione per la BFS
        
for (VertexImpl<Stringnode nodes) { //per tutti i vertici raggiungibili da quello corrente
            
if (visited.contains(node) || node.equals(destination)) { //se è già stato visitato o se è quello cercato
                
continue;
            }
            
visited.addLast(node); //segna il vertice come visitato
            
bfs(gvisitedpathsdestination); //chiamo ricorsivamente la funzione bfs
            
visited.removeLast(); //rimuovo l'ultimo vertice visitato
        
}

        return 
paths//ritorno i percorsi trovati
    

Alhazred è offline   Rispondi citando il messaggio o parte di esso
Old 14-06-2012, 19:11   #2
Alhazred
Senior Member
 
L'Avatar di Alhazred
 
Iscritto dal: Dec 2003
Messaggi: 1765
Si, agli archi sono associati dei pesi.
Comunque il fatto di scartare il secondo percorso che ho indicato è perché ti fa partire da A prendendo la linea 2, arrivato in B ti fa cambiare e prendere la linea1, poi di nuovo alla fermata seguente ti fa prendere la linea iniziale.
Tu da viaggiatore faresti mai una cosa simile?

Non lo scarto perché è un percorso sbagliato, ma perché non è logicamente accettabile.
Alhazred è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'' per spingere gli handheld gaming PC al massimo Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'...
AWS re:Invent 2025: inizia l'era dell'AI-as-a-Service con al centro gli agenti AWS re:Invent 2025: inizia l'era dell'AI-as-a-Se...
Cos'è la bolla dell'IA e perché se ne parla Cos'è la bolla dell'IA e perché se...
BOOX Palma 2 Pro in prova: l'e-reader diventa a colori, e davvero tascabile BOOX Palma 2 Pro in prova: l'e-reader diventa a ...
FRITZ!Repeater 1700 estende la rete super-veloce Wi-Fi 7 FRITZ!Repeater 1700 estende la rete super-veloce...
Cloud sovrano: l'approccio di Broadcom c...
HONOR conferma l'arrivo in Italia di Mag...
La Cina sotto pressione impone maniglie ...
OpenAI integra le app in ChatGPT per tra...
NVIDIA sarebbe pronta a tagliare la prod...
Prezzo minimo storico per iPhone 16 Pro:...
Riot Games scopre una falla nei BIOS che...
Beats in super offerta su Amazon: aurico...
Batterie elettriche, Samsung SDI e Stell...
Clivet presenta Fullness, la pompa di ca...
SpaceX lancerà 167 razzi spaziali...
Yakuza Kiwami 3 e Dark Ties protagonisti...
Privacy a rischio: ecco la VPN che regis...
SpaceX ha annunciato che un satellite St...
ASUSTOR presenta i nuovi NAS Lockerstor ...
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: 03:06.


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