Use bfs function included here.
https://github.com/prabushitha/DataStructures/blob/master/Graph/GraphBFS.py
Output:
bfs(graph,source) returns an array with shortest distances for each vertex in the graph
array element is None when there's no path
Usage:
If you want to print distances from 3 to other vertexes, call bfs function with the source vertex 3.
print(bfs(graph,3))
Saturday, November 14, 2015
Tuesday, November 10, 2015
Creating a graph according the user input
Firstly,
මේ පයිතන් graph class 2ක දාගන්න (class Node and class Graph)
https://raw.githubusercontent.com/prabushitha/DataStructures/master/Graph/GraphAL.py
Okay!
මේ පයිතන් graph class 2ක දාගන්න (class Node and class Graph)
https://raw.githubusercontent.com/prabushitha/DataStructures/master/Graph/GraphAL.py
Okay!
දැන් User input දෙන්නේ මේ විදියට කියලා හිතමු
1 2
1 3
2 4
4 5
END
ඉහත ආකාරය දක්වා ඇත්තේ
Edge එක පටන් ගන්න Vertex එක <SPACE> Edge එක ඉවර වෙන Vertex එක
eg. 1 2 කියලා කියන්නේ
පලවෙනි Vertex එකේ ඉදන් දෙවනි Vertex එකට Edge එකක් තියන්වයි කියල.
END කියලා input එක දුන්නම එතනින් ඉවරයි කියලා ගන්නවා
So, the graph should look like this
data:image/s3,"s3://crabby-images/779f8/779f80b964ea3ccde78b93a420d9cf29ea54462f" alt=""
ඕක graph එකට දාගන්න කෝඩ් එක දැන් අපි ලියමු.
graph = Graph()
while(True):
userInput = str(input())
if(userInput=="END"):
break
vertexFrom = userInput.split()[0]
vertexTo = userInput.split()[1]
#Creating the vertexes if vertexes are not already created
if(not graph.isVertex(vertexFrom)):
graph.addVertex(vertexFrom)
if(not graph.isVertex(vertexTo)):
graph.addVertex(vertexTo)
graph.addEdge(vertexFrom,vertexTo)
print(graph)
ඔච්චර තමා කරන්න තියෙන්නේ. ඊට පස්සේ තියෙන්නේ හදාගත්ත graph එකෙන් වැඩ ගන්න එක :-D
ඒ කියන්නේ BFS දාල Shortest path හොයන සීන් වගේ එව්වා :-D
<download fullcode here: https://raw.githubusercontent.com/prabushitha/DataStructures/master/Graph/Example/GraphExample.py >
1 3
2 4
4 5
END
ඉහත ආකාරය දක්වා ඇත්තේ
Edge එක පටන් ගන්න Vertex එක <SPACE> Edge එක ඉවර වෙන Vertex එක
eg. 1 2 කියලා කියන්නේ
පලවෙනි Vertex එකේ ඉදන් දෙවනි Vertex එකට Edge එකක් තියන්වයි කියල.
END කියලා input එක දුන්නම එතනින් ඉවරයි කියලා ගන්නවා
So, the graph should look like this
data:image/s3,"s3://crabby-images/779f8/779f80b964ea3ccde78b93a420d9cf29ea54462f" alt=""
ඕක graph එකට දාගන්න කෝඩ් එක දැන් අපි ලියමු.
graph = Graph()
while(True):
userInput = str(input())
if(userInput=="END"):
break
vertexFrom = userInput.split()[0]
vertexTo = userInput.split()[1]
#Creating the vertexes if vertexes are not already created
if(not graph.isVertex(vertexFrom)):
graph.addVertex(vertexFrom)
if(not graph.isVertex(vertexTo)):
graph.addVertex(vertexTo)
graph.addEdge(vertexFrom,vertexTo)
print(graph)
ඔච්චර තමා කරන්න තියෙන්නේ. ඊට පස්සේ තියෙන්නේ හදාගත්ත graph එකෙන් වැඩ ගන්න එක :-D
ඒ කියන්නේ BFS දාල Shortest path හොයන සීන් වගේ එව්වා :-D
<download fullcode here: https://raw.githubusercontent.com/prabushitha/DataStructures/master/Graph/Example/GraphExample.py >
Monday, November 9, 2015
Graph implementation using linkedlists
Here's my python class(Includes class Node and class Graph)
https://raw.githubusercontent.com/prabushitha/DataStructures/master/Graph/GraphAL.py
Usage
#After copying/importing above 2 classes to your code
#Creating a new graph
graph = Graph()
#Adding a vertex. e.g add 2 vertexes A and B
graph.addVertex("A")
graph.addVertex("B")
#Adding an edge between 2 vertexes
graph.addEdge("A","B")
#Check whether there's an edge between 2 vertexes. e.g from A to B (returns True/False)
graph.isEdge("A","C")
#Check whether there's a path from one vertex to another. e.g from A to B (returns True/False)
graph.isPath("D","B")
Subscribe to:
Posts (Atom)