Python implementation of Dijkstra and Bi-Directional Dijkstra using heap and priority queues in python