-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathGraph1.py
72 lines (55 loc) · 1.68 KB
/
Graph1.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
# -*- coding: utf-8 -*-
"""
Created on Thu Jun 14 20:55:21 2018
@author: Tirtha
"""
class Node (object):
def __init__(self,name):
self.name=name
def getName(self):
return (self.name)
def __str__(self):
return (self.name)
class Edge (object):
def __init__(self,src,dest):
self.src=src
self.dest=dest
def getSource(self):
return (self.src)
def getDest(self):
return (self.dest)
def __str__(self):
return (self.src.getName()+"->"+self.dest.getName())
class Digraph(object):
def __init__(self):
self.edges={}
def addNode(self,node):
if node in self.edges:
raise ValueError("Duplicate node")
else:
self.edges[node]=[]
def addEdge(self,edge):
src=edge.getSource()
dest=edge.getDest()
if (src not in self.edges) and (dest not in self.edges):
raise ValueError("Node not in graph")
else:
self.edges[src].append(dest) # Builds adjacency list
def childrenOf(self,node):
return self.edges[node]
def hasNode(self,node):
return node in self.edges
def getNode(self,name):
for n in self.edges:
if n.getName()==name:
return n
raise NameError(name)
def __str__(self):
toPrint=''
for src in self.edges:
for dest in self.edges[src]:
toPrint=toPrint+src.getName()+"->"+dest.getName()+"\n"
if (toPrint==''):
return ("Empty graph! Nothing to print")
else:
return toPrint[:-1]