interactive-coding-challenges/graphs_trees/graph/graph.py

27 lines
651 B
Python
Raw Normal View History

2015-08-05 07:37:05 +08:00
from collections import OrderedDict
class Node:
def __init__(self, id):
self.id = id
2015-08-05 07:37:05 +08:00
self.visited = False
self.adjacent = OrderedDict() # key = node, val = weight
class Graph:
def __init__(self):
2015-08-05 07:37:05 +08:00
self.nodes = OrderedDict() # key = node id, val = node
def add_node(self, id):
node = Node(id)
self.nodes[id] = node
return node
def add_edge(self, source, dest, weight=0):
if source not in self.nodes:
self.add_node(source)
if dest not in self.nodes:
self.add_node(dest)
2015-08-05 07:37:05 +08:00
self.nodes[source].adjacent[self.nodes[dest]] = weight