leetcode-163周赛-1263-推箱子*
题目描述:


自己的提交:
class Solution:
def minPushBox(self, grid: List[List[str]]) -> int:
driction = [(0,1),(0,-1),(-1,0),(1,0)]
for i in range(len(grid)):
for j in range(len(grid[0])):
if grid[i][j] == "B":
box = (i,j)
if grid[i][j] == "S":
grid[i][j] = "."
start = (i,j)
if grid[i][j] == "T":
grid[i][j] = "."
target = (i,j) def dfs(start,end,visited):
visited.add(start)
if start == end:
return True
for i_,j_ in driction:
i,j = start[0] + i_,start[1] + j_
if 0<=i<len(grid) and 0<=j<len(grid[0]) and (grid[i][j] == "." /
or grid[i][j] == "B") and (i,j) not in visited and dfs((i,j),end,visited):
return True
return False
visited = set()
queue = [] queue.append((box[0],box[1],start[0],start[1]))
visited.add((box[0],box[1],start[0],start[1]))
res = -1
while queue:
tmp = []
res += 1
for i,j,x,y in queue:
if target == (i,j):
return res
if 0 <= j-1 < j+1 < len(grid[0]) and grid[i][j-1] != "#" and grid[i][j+1] != "#":
if (i,j-1,i,j) not in visited and dfs((x,y),(i,j+1),{(i,j)}):
visited.add((i,j-1,i,j))
tmp.append((i,j-1,i,j))
if (i,j+1,i,j) not in visited and dfs((x,y),(i,j-1),{(i,j)}):
visited.add((i,j+1,i,j))
tmp.append((i,j+1,i,j))
if 0 <= i-1 < i+1 < len(grid) and grid[i-1][j] != "#" and grid[i+1][j] != "#":
if (i-1,j,i,j) not in visited and dfs((x,y),(i+1,j),{(i,j)}):
visited.add((i-1,j,i,j))
tmp.append((i-1,j,i,j))
if (i+1,j,i,j) not in visited and dfs((x,y),(i-1,j),{(i,j)}):
visited.add((i+1,j,i,j))
tmp.append((i+1,j,i,j))
queue = tmp
return -1
优化:*
class Solution:
def minPushBox(self, grid: List[List[str]]) -> int:
n, m = len(grid), len(grid[0]) for i in range(n):
for j in range(m):
if grid[i][j] == 'T':
t = (i, j)
elif grid[i][j] == 'S':
s = (i, j)
elif grid[i][j] == 'B':
b = (i, j) dirs = [[1, 0], [-1, 0], [0, 1], [0, -1]]
q = [tuple(s + b)]
seen = set(q)
steps = 0
while q:
nq = []
for si, sj, bi, bj in q:
if t == (bi, bj): return steps
for di, dj in dirs:
nsi, nsj = si + di, sj + dj
if nsi == bi and nsj == bj:
nbi, nbj = bi + di, bj + dj
ds = 1
else:
nbi, nbj = bi, bj
ds = 0
if not (0 <= nsi < n and 0 <= nsj < m): continue
if not (0 <= nbi < n and 0 <= nbj < m): continue
if grid[nsi][nsj] == '#' or grid[nbi][nbj] == '#': continue
nsb = (nsi, nsj, nbi, nbj)
if nsb in seen: continue
seen.add(nsb)
if ds == 0:
q.append(nsb)
else:
nq.append(nsb)
q = nq
steps += 1
return -1
leetcode-163周赛-1263-推箱子*的更多相关文章
- OC推箱子
#include<stdio.h> #include<stdlib.h> int main(void) { char sr;//存储用户输入的指令 //绘制地图 char a[ ...
- c语言游戏推箱子
前两天做了推箱子小游戏,看似简单的一个小游戏背后却 有巨大的秘密,这秘密就是一大堆逻辑. 自从学习了函数过后,的确是解决了很多问题,而且调用很方便,尽管我现在都不是很会调用. 写完一个函数,准备测试一 ...
- JavaScript写一个小乌龟推箱子游戏
推箱子游戏是老游戏了, 网上有各种各样的版本, 说下推箱子游戏的简单实现,以及我找到的一些参考视频和实例: 推箱子游戏的在线DEMO : 打开 如下是效果图: 这个拖箱子游戏做了移动端的适配, 我使用 ...
- 用C#制作推箱子小游戏
思路分析: 一.制作一个地图 二.地图中放置墙.箱子.人.目标等 三.让小人动起来完成推箱子动作 游戏制作: 1.按照上述地图制作一个地图 (12行×13列) 地图可以看做是行和列组成的,即可以看做 ...
- hdu.1254.推箱子(bfs + 优先队列)
推箱子 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total Submis ...
- [游戏模版17] Win32 推箱子 迷宫
>_<:Here introduce a simple game: >_<:resource >_<:only can push a box and finally ...
- [转]Flash ActionScript2.0面向对象游戏开发-推箱子
本文转自:http://www.alixixi.com/Dev/W3C/Flash/2007/2007070868666.html 概述: Flash ActionScript2.0是一种面向对向的编 ...
- c#部分---网吧充值系统;简易的闹钟;出租车计费;简单计算器;对战游戏;等额本金法计算贷款还款利息等;随机生成10个不重复的50以内的整数;推箱子;
网吧充值系统namespace ConsoleApplication1 { class Program { struct huiyuan { public string name; public st ...
- c++、c实现推箱子小游戏
经过四次的修改和优化,终于将推箱子这个游戏完整的写出来了,今天就像大家分享一下这个游戏的编写. 这个游戏界面的编写总的来说不困难,主要是推动箱子的算法. (1)利用数组和windows api 即可写 ...
- [HDU 1254] 推箱子
推箱子 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total Submis ...
随机推荐
- react 使用axios
1.配置axios代理 使得axios 可以不写根路径 package.json "proxy":"http://localhost:4000", 2.使用 ...
- css 多行省略号兼容移动端
浏览器兼容css样式 -webkit-line-clamp: ; display: -webkit-box; overflow: hidden; text-overflow: ellipsis; te ...
- 用List和Map排序输出
参考:java的treemap反序输出 int->string string->int java对象数组的概述 List import java.io.*; import java.uti ...
- Delphi DBGrid 实现复选框
1 在数据库对应的表中加入 bit 列验证是否被选中 然后dbgrid第一列的filedname是bit列 在DBgrid的onDrawColumnCell事件中写: procedure DBGri ...
- PyCharm 默认快捷键
1.编辑(Editing) Ctrl + Space 基本的代码完成(类.方法.属性)Ctrl + Alt + Space 快速导入任意类Ctrl + Shift + Enter 语句完 ...
- 【Shiro】五、Apache Shiro加密
Shiro提供了更好封装,更好使用的加密算法API,可以作为平时使用的一个工具类的预选方案. Shiro的密码学 基本特性 接口驱动,基于POJO 对JCE(Java Cryptography Ext ...
- Oracle 用户概念与基本操作
目录 目录 Oracle的用户 通过系统用户来登陆SQLPlus system和sys的区别 查看登陆的用户 启用和锁定一个用户 启用用户 锁定用户 创建用户 修改用户 删除用户 角色权限 常用的用户 ...
- composer 手动安装及简单使用 windows
1.配置系统变量 Path 计算机->高级系统设置->环境变量->找到系统变量Path 双击 加入 ;php根目录地址:php中ext地址 如 :“;D:\phpStudy ...
- win10 打开 sql sever配置管理器
!找到解决办法啦!WIN10系统 此电脑->右击->管理弹出以上界面啊哈哈哈还有一些解决办法在这个贴吧里...http://tieba.baidu.com/p/3000709047
- upc组队赛6 GlitchBot【枚举】
GlitchBot 题目描述 One of our delivery robots is malfunctioning! The job of the robot is simple; it shou ...