Dikstra的概念是BFS ,只是把BFS的Queue換成MInheap, 每次去取最小執行去找到最短路徑的演算法,是一種Greedy的演算法
Step:
- 會需要一個min_heap和done_set
- 把起始值放進去
- 先去pop, pop出來的東西會是距離和node
- 檢查點是否在done_set內
- 從node去拜訪鄰居 把結果存到minHeap
- 檢查鄰居是否完成 (有沒有在doneset內)
- 0完成後用一個set記起來,防止minHeap內還有0
- 重複第3點之後的動作
505. The Maze II
data:image/s3,"s3://crabby-images/1b19b/1b19b570fbfaf723dc5a3aa8e0bc4d1356b44ba8" alt=""
743. Network Delay Time
data:image/s3,"s3://crabby-images/4e589/4e589c96c9b90313325f796c84352f623fe18559" alt=""
data:image/s3,"s3://crabby-images/47ca7/47ca7a654b8f32589b55dcb73f74055f4a6ea2e3" alt=""
1293. Shortest Path in a Grid with Obstacles Elimination
data:image/s3,"s3://crabby-images/2b15e/2b15e88cc16397213a8ce3a056f6b1a3e3ed5910" alt=""
1631. Path With Minimum Effort
data:image/s3,"s3://crabby-images/df740/df7401fc96bac315e5f8fa6ba258104623818485" alt=""
1102. Path With Maximum Minimum Value
data:image/s3,"s3://crabby-images/06ba0/06ba0c525d6f1a5977295757261770a63d80d802" alt=""
1091. Shortest Path in Binary Matrix
data:image/s3,"s3://crabby-images/c655d/c655d771a6184dc35debd5b41fe5850cf19acef4" alt=""