LeetCode题解1263. 推箱子

「推箱子」是一款风靡全球的益智小游戏,玩家需要将箱子推到仓库中的目标位置。

游戏地图用大小为 n * m 的网格 grid 表示,其中每个元素可以是墙、地板或者是箱子。

现在你将作为玩家参与游戏,按规则将箱子 'B' 移动到目标位置 'T' :

玩家用字符 'S' 表示,只要他在地板上,就可以在网格中向上、下、左、右四个方向移动。

地板用字符 '.' 表示,意味着可以自由行走。

墙用字符 '#' 表示,意味着障碍物,不能通行。 

箱子仅有一个,用字符 'B' 表示。相应地,网格上有一个目标位置 'T'。

玩家需要站在箱子旁边,然后沿着箱子的方向进行移动,此时箱子会被移动到相邻的地板单元格。记作一次「推动」。

玩家无法越过箱子。

返回将箱子推到目标位置的最小 推动 次数,如果无法做到,请返回 -1。

 

示例 1:

LeetCode题解1263. 推箱子

输入:grid = [["#","#","#","#","#","#"],

["#","T","#","#","#","#"],

  ["#",".",".","B",".","#"],

  ["#",".","#","#",".","#"],

  ["#",".",".",".","S","#"],

  ["#","#","#","#","#","#"]]

输出:3

解释:我们只需要返回推箱子的次数。

示例 2:

输入:grid = [["#","#","#","#","#","#"],

["#","T","#","#","#","#"],

  ["#",".",".","B",".","#"],

  ["#","#","#","#",".","#"],

  ["#",".",".",".","S","#"],

  ["#","#","#","#","#","#"]]

输出:-1

示例 3:

输入:grid = [["#","#","#","#","#","#"],

  ["#","T",".",".","#","#"],

  ["#",".","#","B",".","#"],

  ["#",".",".",".",".","#"],

  ["#",".",".",".","S","#"],

  ["#","#","#","#","#","#"]]

输出:5

解释:向下、向左、向左、向上再向上。

示例 4:

输入:grid = [["#","#","#","#","#","#","#"],

  ["#","S","#",".","B","T","#"],

  ["#","#","#","#","#","#","#"]]

输出:-1

 

提示:

1 <= grid.length <= 20

1 <= grid[i].length <= 20

grid 仅包含字符 '.', '#',  'S' , 'T', 以及 'B'。

grid 中 'S', 'B' 和 'T' 各只能出现一个。

来源:力扣(LeetCode)

链接:https://leetcode-cn.com/problems/minimum-moves-to-move-a-box-to-their-target-location

著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

LeetCode题解计算机为什么是基于二进制的?

可以是三进制么?二进制有什么好处?题解:为什么叫电子计算机?算盘应该没有二进制

LeetCode题解深度优先遍历和回溯的关系?

深度优先遍历的范围更大还是回溯的范围更大?为什么?题解:我的理解是:dfs是回溯思想的一种体现- 回溯:是在整个搜索空间中搜索出可行解,在搜索过程中不断剪枝回退,这是回溯的思想,这个搜索空间并没有限制于特定的数据结构。- dfs:dfs是指特定的数据结构中如图,树(特殊的图)中搜索答案,范围限制在了特定的数据结构。个人拙见。

LeetCode题解盲人买袜子。

他们都各自买了两对黑袜和两对白袜,八对袜子的布质、大小完全相同,而每对袜子都有一张商标纸连着。两位盲人不小心将八对袜子混在一起。他们每人怎样才能取回黑袜和白袜各两对呢?题解:暴力破解, 把袜子都拆开 一人一只 哈哈

LeetCode题解10个小球,随机分到12个盒子里,求恰好10个盒子都为空的概率。

10个小球,随机分到12个盒子里,求恰好10个盒子都为空的概率。要求用程序模拟十万次,暴力求出该概率来自:字节跳动 算法工程师一面的第一题 (3月30日,60分钟,牛客网视频面)https://www.nowcoder.com/discuss/395924

LeetCode题解微信红包

微信红包 如何分配 让每个人在数学期望上是一样的?在概率论和统计学中,数学期望(mean)(或均值,亦简称期望)是试验中每次可能结果的概率乘以其结果的总和,是最基本的数学特征之一。 它反映随机变量平均取值的大小。 需要注意的是,期望值并不一定等同于常识中的“期望”——“期望值”也许与每一个结果都不相等。 期望值是该变量输出值的平均数。