0-1BFS目前我只在最短路问题遇到,使用双端队列优化为复杂度O(VE)。
当边权只有0或1时,可以使用0-1BFS,否则请使用dijkstra等最短路算法。
实际上0-1BFS和dijkstra是很相似的,都是控制下个节点的访问顺序;不同之处在于,dijkstra需要给堆传入优先级来决定优先访问哪个;0-1BFS的优先级是明确的。
由于复杂度提升的不多,赛中还是建议优先使用dijkstra吧。
例题: 2290. 到达角落需要移除障碍物的最小数目
DIRS = [(0,1),(0,-1),(1,0),(-1,0)]
class Solution:def minimumObstacles(self, grid: List[List[int]]) -> int:m,n = len(grid),len(grid[0])def inside(x,y):return 0<=xd:dist[a][b] = dif grid[a][b] == 0:q.appendleft((a,b))else:q.append((a,b)) return -1
链接: 1368. 使网格图至少有一条有效路径的最小代价
DIRS = [(0,1),(0,-1),(1,0),(-1,0)]
class Solution:def minCost(self, grid: List[List[int]]) -> int:m,n = len(grid),len(grid[0])def inside(x,y):return 0<=x dist[x][y]:continuefor i,(dx,dy) in enumerate(DIRS,1):a,b = x+dx,y+dy if inside(a,b):w = int(grid[x][y] != i)d = c + wif d < dist[a][b]:dist[a][b] = d if w>0:q.append((d,a,b))else:q.appendleft((d,a,b))return -1