MHB Counting shortest paths in a non-directed graph using BFS

  • Thread starter Thread starter evinda
  • Start date Start date
AI Thread Summary
The discussion focuses on finding an algorithm to calculate the number of shortest paths between two nodes, v and u, in a non-directed graph G. The proposed solution involves using Breadth-First Search (BFS) to traverse the graph. During the BFS process, as nodes are added to the queue, the algorithm also counts the number of shortest paths leading to each node. This approach is suggested to operate within the desired time complexity of O(n + m), where n is the number of vertices and m is the number of edges. Participants are encouraged to implement the algorithm and evaluate its effectiveness and performance.
evinda
Gold Member
MHB
Messages
3,741
Reaction score
0
Hello! (Wave)

A non-directed graph $G=(V,E)$ and two nodes $v$ and $u$ of $G$ are given. Give an algorithm that calculates the number of shortest paths $v-u$ in $G$. (The algorithm doesn't have to print all the paths, just how many exist.) The algorithm should run in time $O(n+m)$ for a graph with $n$ vertices and $m$ edges. Is it like that?

We apply BFS. At the point where we add the nodes in the queue, we calculate also the number of nodes.
 
Technology news on Phys.org
What do you think? Have you tried implementing it to see if it sort of works, try and measure the complexity, ...?
 
Dear Peeps I have posted a few questions about programing on this sectio of the PF forum. I want to ask you veterans how you folks learn program in assembly and about computer architecture for the x86 family. In addition to finish learning C, I am also reading the book From bits to Gates to C and Beyond. In the book, it uses the mini LC3 assembly language. I also have books on assembly programming and computer architecture. The few famous ones i have are Computer Organization and...
I have a quick questions. I am going through a book on C programming on my own. Afterwards, I plan to go through something call data structures and algorithms on my own also in C. I also need to learn C++, Matlab and for personal interest Haskell. For the two topic of data structures and algorithms, I understand there are standard ones across all programming languages. After learning it through C, what would be the biggest issue when trying to implement the same data...

Similar threads

Back
Top