[python刷题模板] 0-1BFS
admin
2024-02-17 23:41:34
0

[python刷题模板] 0-1BFS

    • 一、 算法&数据结构
      • 1. 描述
      • 2. 复杂度分析
      • 3. 常见应用
      • 4. 常用优化
    • 二、 模板代码
      • 1. 去除障碍物的矩阵搜索
      • 2. 修改传送方向的矩阵搜索
    • 三、其他
    • 四、更多例题
    • 五、参考链接

一、 算法&数据结构

1. 描述

0-1BFS目前我只在最短路问题遇到,使用双端队列优化为复杂度O(VE)。
当边权只有0或1时,可以使用0-1BFS,否则请使用dijkstra等最短路算法。
实际上0-1BFS和dijkstra是很相似的,都是控制下个节点的访问顺序;不同之处在于,dijkstra需要给堆传入优先级来决定优先访问哪个;0-1BFS的优先级是明确的。
由于复杂度提升的不多,赛中还是建议优先使用dijkstra吧。
  • 当边权只有1时,我们可以用朴素BFS来找最短路;当边权有非负数时,我们可以用dijkstra。
  • 它们的特点是用队列/优先队列来保证:优先出队的一定是当前最该处理的节点。
  • 考虑当边权只有0或者1的情况,假设当前从u转移到v:
    • 若w=1,则v的最短路d=dist[u]+1,应入队;推之前队列中不存在dist小于d的节点。显然v应该最后出队,则dq.append(v)。
    • 若w=0,则v的最短路d=dist[u]+0=dist[u],应入队;我们知道u是当前最小节点,如果v的优先级=u,那么完全可以立刻处理,即优先出队(下一个出队),则dq.appendleft(v)。

2. 复杂度分析

  1. O(VE),即节点数乘边数。

3. 常见应用

  1. 边权只有0或1的最短路搜索。

4. 常用优化

  1. dis初始化为inf,避免使用vis标记数组。

二、 模板代码

1. 去除障碍物的矩阵搜索

例题: 2290. 到达角落需要移除障碍物的最小数目

  • 目标位置存在则边权是1.否则是0
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

2. 修改传送方向的矩阵搜索

链接: 1368. 使网格图至少有一条有效路径的最小代价

  • 显然如果顺着原方向,代价(修改次数)=0;否则代价=1.
  • 代码实现时,对dir按题意顺序,然后偏移下标来模拟方向。
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

三、其他

  1. 其实用不太到这个算法,考试时候肯定是优先用dijkstra了

四、更多例题

五、参考链接

  • 链接: [python刷题模板] 最短路(Dijkstra)

相关内容

热门资讯

斗金订购APP贵金属期货投资被...   斗金订购APP的投资者被广告宣传给诱导,注册就送什么现金,然后充值返现金卷等等这些宣传方式,都是...
哈易购APP非法期货交易欺骗投...   哈易购APP宣传可做白银铂金贵金属订购交易,但实际上并没有取得相关交易资质!哈易购APP本质上就...
消息称百度旗下昆仑芯瞄准500... 6 月 29 日消息,据《The Information》昨日援引知情人士消息,百度旗下 AI 芯片...
打造夏日消费新场景 第35届北... 北京商报讯(记者 翟枫瑞)6月29日消息,第35届北京国际燕京啤酒文化节新闻发布会在京举行。本届啤酒...
社保基金持仓数据出炉,一季度增... 最近各大上市公司一季度财报都公开了,咱们国家社保基金的持仓数据也全部曝光。目前社保拿着比亚迪价值44...
36氪首发 | 海思、中兴团队... 作者 | 乔钰杰 编辑 | 袁斯来 硬氪获悉,广州宸思通讯科技有限公司(以下简称“宸思科技”)近日完...
两天蒸发47亿市值!一纸税务通... 一纸税务通知书,能让一家百亿龙头两天蒸发47亿市值。 6月22日,北大荒(600598.SH)公告称...
SK海力士将投资1100万亿韩... SK集团会长崔泰源6月29日在韩国“三大重大计划”发布会上宣布,公司将投资1100万亿韩元扩大半导体...
两只A股,终止上市! 两家A股公司,即将摘牌。 6月29日,退市沪科(600608.SH)公告称,上海证券交易所将在202...
原创 M... 一家成立近十年的自动驾驶公司,在IPO时吸引了14家基石投资者认购近一半的发行股份,其中不乏奔驰、比...
基金忠言|国寿安保滤镜碎,三年... 图片来源:视觉中国 蓝鲸新闻6月29日讯(记者 祁和忠)保险系基金公司国寿安保总经理换人了。 6月2...
三星电机计划加码玻璃基板!相关... 6月29日,玻璃基板概念股午后有所回升, 华工科技(000988.SZ)逼近涨停, 彩虹股份(600...
拉萨海关持续壮大外贸经营主体 ...   新华网拉萨6月28日电(记者蒋梦辰)近日,记者从拉萨海关获悉,今年前5个月,西藏有进出口实绩的外...
机构:二季报临近,医药生物板块... 6月29日,华源证券发布了一篇医药生物行业的研究报告,报告指出,业绩期临近,产业链景气度有望再次迎来...
每日收评科创50放量涨超4.5... 财联社6月29日讯,三大指数全线收红,创业板指探底回升,科创50指数大涨4.61%。沪深两市成交额3...
6月多地土拍结构性升温:深圳单... 进入2026年6月,不少城市核心区地块集中诞生高溢价宗地,热度突出的城市包含深圳、杭州、长沙。 其中...
业绩炸裂!盛达资源半年预盈3.... 6月29日,贵金属矿山龙头盛达资源(000603.SZ)发布 2026 年半年度业绩预告,上半年业绩...
A股午后拉升三大股指收涨:半导... A股三大股指6月29日开盘涨跌互现。早盘沪强深弱,创指一度跌超2%。半导体午后拉升,带动两市上涨,沪...
原创 空... 前言 大家好,我是老金。 这几天,两幅极度割裂的画面放在一起,把我看笑了。 一边是在持续的热浪下,欧...