Skip to content

Commit

Permalink
[mypy] Type annotations for graphs directory (TheAlgorithms#5798)
Browse files Browse the repository at this point in the history
* Type annotations for `breadth_first_search.py`

* Type annotations for `breadth_first_search_2.py`

* Remove from excluded in mypy.ini

* Add doctest.testmod()

* Type annotations for `graphs/check_cycle.py`

* Type annotations for `graphs/greedy_min_vertex_cover.py`

* Remove from excluded in mypy.ini
  • Loading branch information
Rohanrbharadwaj authored Nov 8, 2021
1 parent 4c9949f commit ed4c92d
Show file tree
Hide file tree
Showing 5 changed files with 12 additions and 12 deletions.
2 changes: 1 addition & 1 deletion graphs/breadth_first_search.py
Original file line number Diff line number Diff line change
Expand Up @@ -53,7 +53,7 @@ def bfs(self, start_vertex: int) -> set[int]:
visited = set()

# create a first in first out queue to store all the vertices for BFS
queue = Queue()
queue: Queue = Queue()

# mark the source node as visited and enqueue it
visited.add(start_vertex)
Expand Down
5 changes: 4 additions & 1 deletion graphs/breadth_first_search_2.py
Original file line number Diff line number Diff line change
Expand Up @@ -32,7 +32,7 @@ def breadth_first_search(graph: dict, start: str) -> set[str]:
'ABCDEF'
"""
explored = {start}
queue = Queue()
queue: Queue = Queue()
queue.put(start)
while not queue.empty():
v = queue.get()
Expand All @@ -44,4 +44,7 @@ def breadth_first_search(graph: dict, start: str) -> set[str]:


if __name__ == "__main__":
import doctest

doctest.testmod()
print(breadth_first_search(G, "A"))
6 changes: 2 additions & 4 deletions graphs/check_cycle.py
Original file line number Diff line number Diff line change
Expand Up @@ -6,16 +6,15 @@
def check_cycle(graph: dict) -> bool:
"""
Returns True if graph is cyclic else False
>>> check_cycle(graph={0:[], 1:[0, 3], 2:[0, 4], 3:[5], 4:[5], 5:[]})
False
>>> check_cycle(graph={0:[1, 2], 1:[2], 2:[0, 3], 3:[3]})
True
"""
# Keep track of visited nodes
visited = set()
visited: set[int] = set()
# To detect a back edge, keep track of vertices currently in the recursion stack
rec_stk = set()
rec_stk: set[int] = set()
for node in graph:
if node not in visited:
if depth_first_search(graph, node, visited, rec_stk):
Expand All @@ -27,7 +26,6 @@ def depth_first_search(graph: dict, vertex: int, visited: set, rec_stk: set) ->
"""
Recur for all neighbours.
If any neighbour is visited and in rec_stk then graph is cyclic.
>>> graph = {0:[], 1:[0, 3], 2:[0, 4], 3:[5], 4:[5], 5:[]}
>>> vertex, visited, rec_stk = 0, set(), set()
>>> depth_first_search(graph, vertex, visited, rec_stk)
Expand Down
9 changes: 4 additions & 5 deletions graphs/greedy_min_vertex_cover.py
Original file line number Diff line number Diff line change
Expand Up @@ -2,15 +2,14 @@
* Author: Manuel Di Lullo (https://github.com/manueldilullo)
* Description: Approximization algorithm for minimum vertex cover problem.
Greedy Approach. Uses graphs represented with an adjacency list
URL: https://mathworld.wolfram.com/MinimumVertexCover.html
URL: https://cs.stackexchange.com/questions/129017/greedy-algorithm-for-vertex-cover
"""

import heapq


def greedy_min_vertex_cover(graph: dict) -> set:
def greedy_min_vertex_cover(graph: dict) -> set[int]:
"""
Greedy APX Algorithm for min Vertex Cover
@input: graph (graph stored in an adjacency list where each vertex
Expand All @@ -21,7 +20,7 @@ def greedy_min_vertex_cover(graph: dict) -> set:
{0, 1, 2, 4}
"""
# queue used to store nodes and their rank
queue = []
queue: list[list] = []

# for each node and his adjacency list add them and the rank of the node to queue
# using heapq module the queue will be filled like a Priority Queue
Expand Down Expand Up @@ -61,5 +60,5 @@ def greedy_min_vertex_cover(graph: dict) -> set:

doctest.testmod()

# graph = {0: [1, 3], 1: [0, 3], 2: [0, 3, 4], 3: [0, 1, 2], 4: [2, 3]}
# print(f"Minimum vertex cover:\n{greedy_min_vertex_cover(graph)}")
graph = {0: [1, 3], 1: [0, 3], 2: [0, 3, 4], 3: [0, 1, 2], 4: [2, 3]}
print(f"Minimum vertex cover:\n{greedy_min_vertex_cover(graph)}")
2 changes: 1 addition & 1 deletion mypy.ini
Original file line number Diff line number Diff line change
Expand Up @@ -2,4 +2,4 @@
ignore_missing_imports = True
install_types = True
non_interactive = True
exclude = (graphs/breadth_first_search.py|graphs/breadth_first_search_2.py|graphs/check_cycle.py|graphs/greedy_min_vertex_cover.py|matrix_operation.py|other/least_recently_used.py|other/lfu_cache.py|other/lru_cache.py|searches/simulated_annealing.py|searches/ternary_search.py)
exclude = (matrix_operation.py|other/least_recently_used.py|other/lfu_cache.py|other/lru_cache.py|searches/simulated_annealing.py|searches/ternary_search.py)

0 comments on commit ed4c92d

Please sign in to comment.