LeetCode 采坑两次后,我终于学会了 BFS

上周末的时候参加 LeetCode 周赛,碰到了一道题。感觉很有意思,而且收获也不小,记录一下。

题目链接如下:

https://leetcode-cn.com/problems/map-of-highest-peak/

题目描述:

给你一个大小为 m x n 的整数矩阵 isWater ,它代表了一个由 陆地水域 单元格组成的地图。

  • 如果 isWater[i][j] == 0 ,格子 (i, j)是一个 陆地 格子。
  • 如果 isWater[i][j] == 1 ,格子 (i, j) 是一个 水域 格子。

你需要按照如下规则给每个单元格安排高度:

  • 每个格子的高度都必须是非负的。
  • 如果一个格子是是 水域 ,那么它的高度必须为 0
  • 任意相邻的格子高度差 至多 为 1 。当两个格子在正东、南、西、北方向上相互紧挨着,就称它们为相邻的格子。(也就是说它们有一条公共边)

找到一种安排高度的方案,使得矩阵中的最高高度值 最大

请你返回一个大小为 m x n 的整数矩阵 height ,其中 height[i][j] 是格子 (i, j) 的高度。如果有多种解法,请返回 任意一个


当时时间就剩 20 分钟了,读完题后,也没有啥想法,刚开始就想放弃了。但是感觉又好像在哪见过类似的,好像是之前在 csp 认证的题库上看到的。

又仔细想了想,这就是一个 BFS 嘛, 只不过不同的是这次广度优先进行搜索的时候要从多个源头进行搜索,又称多源 BFS

仿佛看到了希望,于是我赶紧写代码,Debug,输入测试样例,结果不对,再调试,终于在结束前的一分钟把测试样例给调试对了。

赶紧提交代码,结果等了一会后,运行超时了,真是裂开。。。

BFS 提交记录

当时提交的代码如下:

import queue


class Solution:
    def highestPeak(self, isWater: List[List[int]]) -> List[List[int]]:
        q = queue.Queue()
        m, n = len(isWater), len(isWater[0])
        res = [[-1 for _ in range(n)] for _ in 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值