Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Ecovacs Goat O1200 LiDAR Pro: la prova del robot tagliaerba con tagliabordi integrato
Ecovacs Goat O1200 LiDAR Pro: la prova del robot tagliaerba con tagliabordi integrato
Nuova frontiera per i robot tagliaerba, con Ecovacs GOAT O1200 LiDAR Pro che riconosce l'ambiente in maniera perfetta, grazie a due sensori LiDAR, e dopo la falciatura può anche rifinire il bordo con il tagliabordi a filo integrato
Recensione Samsung Galaxy S26+: sfida l'Ultra, ma ha senso di esistere?
Recensione Samsung Galaxy S26+: sfida l'Ultra, ma ha senso di esistere?
Equilibrio e potenza definiscono il Samsung Galaxy S26+, un flagship che sfida la variante Ultra e la fascia alta del mercato con il primo processore mobile a 2nm. Pur mantenendo l'hardware fotografico precedente, lo smartphone brilla per un display QHD+ da 6,7 pollici d'eccellenza, privo però del trattamento antiriflesso dell'Ultra, e per prestazioni molto elevate. Completano il quadro la ricarica wireless a 20W e, soprattutto, un supporto software settennale
Zeekr X e 7X provate: prezzi, autonomia fino a 615 km e ricarica in 13 minuti
Zeekr X e 7X provate: prezzi, autonomia fino a 615 km e ricarica in 13 minuti
Zeekr sbarca ufficialmente in Italia con tre modelli elettrici premium, X, 7X e 001, distribuiti da Jameel Motors su una rete di 52 punti vendita già attivi. La Zeekr X parte da 39.900 euro, la 7X da 54.100: piattaforma a 800V, chip Snapdragon di ultima generazione, ricarica ultraveloce e un'autonomia dichiarata fino a 615 km WLTP. Le prime consegne sono previste a metà aprile
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 14-06-2012, 12:26   #1
Alhazred
Senior Member
 
L'Avatar di Alhazred
 
Iscritto dal: Dec 2003
Messaggi: 1768
[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, 18:11   #2
Alhazred
Senior Member
 
L'Avatar di Alhazred
 
Iscritto dal: Dec 2003
Messaggi: 1768
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


Ecovacs Goat O1200 LiDAR Pro: la prova del robot tagliaerba con tagliabordi integrato Ecovacs Goat O1200 LiDAR Pro: la prova del robot...
Recensione Samsung Galaxy S26+: sfida l'Ultra, ma ha senso di esistere? Recensione Samsung Galaxy S26+: sfida l'Ultra, m...
Zeekr X e 7X provate: prezzi, autonomia fino a 615 km e ricarica in 13 minuti Zeekr X e 7X provate: prezzi, autonomia fino a 6...
Marathon: arriva il Fortnite hardcore Marathon: arriva il Fortnite hardcore
HP Imagine 2026: abbiamo visto HP IQ all’opera, ecco cosa può (e non può) fare HP Imagine 2026: abbiamo visto HP IQ all’opera, ...
Anthropic, con Claude triplicati i ricav...
Questa sedia ergonomica da ufficio a 169...
I 2 migliori portatili su Amazon: gran C...
Speciale monitor MSI: a partire da meno ...
La fine di Fortnite si sta avvicinando? ...
The Last of Us Online: a che punto era e...
MacBook con M5: il raffreddamento attivo...
Samsung contrasta la crisi delle memorie...
Google Meet arriva su CarPlay: le riunio...
Le 10 migliori offerte Amazon di Pasqua:...
Nuove fotografie dagli astronauti di Art...
La toilette della capsula Orion Integrit...
GeForce NOW: ecco tutte le novità in arr...
Il Realme 16 5G debutta sul mercato glob...
HONOR svela tre nuovi tablet: il più int...
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: 08:56.


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