data:image/s3,"s3://crabby-images/ee8ee/ee8eeceb717e18042497ef5c45993d88d20738e6" alt="Basic data structures in python"
data:image/s3,"s3://crabby-images/556d1/556d144a389161c374d83bac7e3ce869e8d19af0" alt="basic data structures in python basic data structures in python"
Self.vert_dict.add_neighbor(self.vert_dict, cost) Self.num_vertices = self.num_vertices + 1 Return str(self.id) + ' adjacent: ' + str()ĭef add_neighbor(self, neighbor, weight=0): In the code, we create two classes: Graph, which holds the master list of vertices, and Vertex, which represents each vertex in the graph: A directed graph with no cycles is called a directed acyclic graph or a DAG. A graph with no cycles is called an acyclic graph.
data:image/s3,"s3://crabby-images/e6dde/e6ddedc0faa08844379083ec1be5c9026f317592" alt="basic data structures in python basic data structures in python"
$$E = \$.Ī cycle in a directed graph is a path that starts and ends at the same vertex. The picture above shows a simple weighted graph and we can represent this graph as the set of six vertices A subgraph $s$ is a set of edges $e$ and vertices $v$ such that $e \in E$ and $v \in V$. We can add a third component to the edge tuple to represent a weight.
data:image/s3,"s3://crabby-images/30b78/30b78c33e0f6628d1e059bd686457daef3ce6585" alt="basic data structures in python basic data structures in python"
Each edge is a tuple $(v,w)$ where $w,v \in V$. $V$ is a set of vertices and $E$ is a set of edges. For example in a graph of roads that connect one city to another, the weight on the edge might represent the distance between the two cities or traffic status.Ī graph can be represented by $G$ where $G=(V,E)$. The picture shown above is not a digraph.Įdges may be weighted to show that there is a cost to go from one vertex to another. If the edges in a graph are all one-way, the graph is a directed graph, or a digraph. A vertex may also have additional information and we'll call it as payload.Īn edge is another basic part of a graph, and it connects two vertices/ Edges may be one-way or two-way. A vertex is the most basic part of a graph and it is also called a node.
data:image/s3,"s3://crabby-images/ee8ee/ee8eeceb717e18042497ef5c45993d88d20738e6" alt="Basic data structures in python"