Torna indietro   Hardware Upgrade Forum > Software > Programmazione

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é
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 colori, e davvero tascabile
BOOX Palma 2 Pro è l'ultima evoluzione della gamma Palma. Ma di cosa si tratta? In breve è un dispositivo e-ink da 6,13 pollici che sfida le convenzioni con un display Kaleido 3 a colori, supporto per stilo InkSense Plus, connettività 5G solo dati e alimentato dal sistema operativo Android 15. Con queste caratteristica si configura come qualcosa in più di un semplice e-reader
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: 1764
[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: 1764
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


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...
Fondazione Chips-IT, l'Italia alla riscossa nei chip. Il piano e la partnership EssilorLuxottica Fondazione Chips-IT, l'Italia alla riscossa nei ...
Le schede video Arc dominano la fascia e...
Auto elettriche sotto la lente dell'Anti...
Palo Alto Networks e IBM collaborano per...
Gemini può ora rilevare i deepfak...
Crisi delle RAM? A quanto pare non per N...
Dreame entra nel mercato smartphone: tra...
Cloudflare, nel 2025 un web a due facce:...
Riot prepara 'League Next': il futuro di...
NVIDIA e AMD interessate a Intel Foundry...
Sentite Volkswagen: "addio piccole ...
Consumo anomalo di RAM su Windows 11: so...
vivo X300 e X300 Pro arrivano su Amazon ...
Apple punta sull'India per la realizzazi...
L'IA inquina quanto l'intera New York: e...
VMware dismette vSphere Foundation in al...
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: 14:44.


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