
Path between 2 nodes in a graph
    5 visualizaciones (últimos 30 días)
  
       Mostrar comentarios más antiguos
    
    Hari
 el 28 de Sept. de 2020
  
    
    
    
    
    Comentada: Christine Tobler
    
 el 5 de Oct. de 2020
            How to check if a path exists between two nodes in a graph?
0 comentarios
Respuesta aceptada
  Michael Croucher
      
 el 28 de Sept. de 2020
        
      Editada: Michael Croucher
      
 el 28 de Sept. de 2020
  
      Take this example graph
s = [1 2 2 3 3 3 4 5 5 5 8 8];
t = [2 3 4 1 4 5 5 3 6 7 9 10];
G = graph(s,t);
plot(G,'Layout','layered')

>> components=conncomp(G)
ans =
     1     1     1     1     1     1     1     2     2     2
We can see that there are two connected components.  To see it nodes 4 and 7 are connected (for example), just see if they are members of the same component.
components(4)==components(7)
ans =
  logical
   1
2 comentarios
  Christine Tobler
    
 el 5 de Oct. de 2020
				Note this works well for an undirected graph, but for directed graphs it would be more complicated: In that case, you'd want to look into digraph/transclosure to get connection between every pair of nodes. 
Más respuestas (1)
  Christine Tobler
    
 el 28 de Sept. de 2020
        Compute a path between the nodes, then check if the result is empty (this is returned by shortestpath if no path exists):
path = shortestpath(G, firstNode, secondNode)
pathExists = ~isempty(path);
2 comentarios
Ver también
Categorías
				Más información sobre Graph and Network Algorithms en Help Center y File Exchange.
			
	Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!



