All Python Version 3

Added functions to get all nodes for some algorithms and time calculation for dfs and bfs.
This commit is contained in:
Safari 2018-12-16 22:19:40 +03:30 committed by GitHub
parent b3a15175bd
commit 069d2b9cb6
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

View File

@ -1,6 +1,7 @@
from collections import deque from collections import deque
import random as rand import random as rand
import math as math import math as math
import time
# the dfault weight is 1 if not assigend but all the implementation is weighted # the dfault weight is 1 if not assigend but all the implementation is weighted
@ -19,7 +20,10 @@ class DirectedGraph:
self.graph[u] = [[w, v]] self.graph[u] = [[w, v]]
if not self.graph.get(v): if not self.graph.get(v):
self.graph[v] = [] self.graph[v] = []
def all_nodes(self):
return list(self.graph)
# handels if the input does not exist # handels if the input does not exist
def remove_pair(self, u, v): def remove_pair(self, u, v):
if self.graph.get(u): if self.graph.get(u):
@ -234,6 +238,18 @@ class DirectedGraph:
if len(stack) == 0: if len(stack) == 0:
return False return False
def dfs_time(self, s = -2, e = -1):
begin = time.time()
self.dfs(s,e)
end = time.time()
return end - begin
def bfs_time(self, s = -2):
begin = time.time()
self.bfs(s)
end = time.time()
return end - begin
class Graph: class Graph:
def __init__(self): def __init__(self):
self.graph = {} self.graph = {}
@ -436,3 +452,17 @@ class Graph:
# check if se have reached the starting point # check if se have reached the starting point
if len(stack) == 0: if len(stack) == 0:
return False return False
def all_nodes(self):
return list(self.graph)
def dfs_time(self, s = -2, e = -1):
begin = time.time()
self.dfs(s,e)
end = time.time()
return end - begin
def bfs_time(self, s = -2):
begin = time.time()
self.bfs(s)
end = time.time()
return end - begin