当前位置: 首页 > wzjs >正文

怎么自己创建一个网站代码百度安装免费下载

怎么自己创建一个网站代码,百度安装免费下载,签合网站是哪个好,东营做网站排名Leetcode 3568. Minimum Moves to Clean the Classroom 1. 解题思路2. 代码实现 题目链接:3568. Minimum Moves to Clean the Classroom 1. 解题思路 这一题我的核心思路就是广度优先遍历遍历剪枝。 显然,我们可以给出一个广度优先遍历来给出所有可能…
  • Leetcode 3568. Minimum Moves to Clean the Classroom
    • 1. 解题思路
    • 2. 代码实现
  • 题目链接:3568. Minimum Moves to Clean the Classroom

1. 解题思路

这一题我的核心思路就是广度优先遍历遍历+剪枝。

显然,我们可以给出一个广度优先遍历来给出所有可能的走法直至无法继续或者捡完所有垃圾。

但是,上述情况事实上可能会无限循环下去,而且所有的走法也非常浪费,因此,我们需要对其进行剪枝,从而优化我们的计算。

而这里,我的剪枝思路就是:

  • 如果一个点曾经走过,则当他重新回到这个点的时候,他必须满足以下两个条件之一,否则这条路线必然不会是最优的,可以直接忽略:
    • 他在中间的过程中捡过了新的垃圾;
    • 他在中间的过程中补充了能量(即回来时的能量值大于之前来的时候的能量值)

由此,我们就能对上述问题进行解答了。

2. 代码实现

给出python代码实现如下:

class Solution:def minMoves(self, classroom: List[str], energy: int) -> int:n, m = len(classroom), len(classroom[0])k, mapping, seen = 0, {}, {}for i in range(n):for j in range(m):if classroom[i][j] == "L":mapping[(i, j)] = kk += 1elif classroom[i][j] == "S":start = (0, 0, -energy, i, j)seen[(0, i, j)] = energyif k == 0:return 0q = [start]while q:step, status, e, i, j = heapq.heappop(q)status = -statuse = -eif status == (2**k)-1:return stepelif e <= 0:continueif i-1 >= 0 and classroom[i-1][j] != "X":new_status = status if classroom[i-1][j] != "L" else status | (1 << mapping[(i-1, j)])new_energy = e-1 if classroom[i-1][j] != "R" else energyif seen.get((new_status, i-1, j), -1) < new_energy:heapq.heappush(q, (step+1, -new_status, -new_energy, i-1, j))seen[(new_status, i-1, j)] = new_energyif i+1 < n and classroom[i+1][j] != "X":new_status = status if classroom[i+1][j] != "L" else status | (1 << mapping[(i+1, j)])new_energy = e-1 if classroom[i+1][j] != "R" else energyif seen.get((new_status, i+1, j), -1) < new_energy:heapq.heappush(q, (step+1, -new_status, -new_energy, i+1, j))seen[(new_status, i+1, j)] = new_energyif j-1 >= 0 and classroom[i][j-1] != "X":new_status = status if classroom[i][j-1] != "L" else status | (1 << mapping[(i, j-1)])new_energy = e-1 if classroom[i][j-1] != "R" else energyif seen.get((new_status, i, j-1), -1) < new_energy:heapq.heappush(q, (step+1, -new_status, -new_energy, i, j-1))seen[(new_status, i, j-1)] = new_energyif j+1 < m and classroom[i][j+1] != "X":new_status = status if classroom[i][j+1] != "L" else status | (1 << mapping[(i, j+1)])new_energy = e-1 if classroom[i][j+1] != "R" else energyif seen.get((new_status, i, j+1), -1) < new_energy:heapq.heappush(q, (step+1, -new_status, -new_energy, i, j+1))seen[(new_status, i, j+1)] = new_energyreturn -1

提交代码评测得到:耗时3097ms,占用内存58.28MB。

http://www.dtcms.com/wzjs/523811.html

相关文章:

  • wordpress编程视频教程seo优化服务是什么意思
  • 武汉做网站公司有哪些千万不要做手游推广员
  • 工程建设其他费百度seo怎么做
  • 手机网站制作套餐精准营销理论
  • 网页设计与网站建设书籍小程序自助搭建平台
  • 怎么做网站多少钱免费论坛建站系统
  • 襄阳万家灯火网站建设成都新闻最新消息
  • 做效果图比较好的模型网站有哪些福州百度关键词排名
  • 动效网站建设宁德市区哪里好玩
  • 电脑网站适应手机如何做腾讯广告投放平台官网
  • 潍坊做网站建设的公司免费seo网站自动推广
  • 百度公司网站排名怎么做可以免费发帖的网站
  • 化妆品企业网站建设的策划方案淘宝客推广有效果吗
  • 做技术开发的网站如何写好软文
  • 网上商城网站建设公司如何建立独立网站
  • 企业培训机构网站源码合肥瑶海区
  • pt网站怎么做手机如何制作一个网页链接
  • 广州网站优化公司如何互联网广告营销方案
  • wordpress百度云对象存储seo快速排名关键词
  • 城乡建设学校网站自媒体平台排名
  • 有关计算机网站建设的论文山东16市最新疫情
  • 视频网站是动态网站吗今天
  • wordpress a5seo关键词是怎么优化的
  • 用vue.js做网站免费学生网页制作成品
  • 网站建设和优化需要几个人爱站数据
  • 网站建设网站模板百度地图导航
  • 重庆网站制作公司多少钱seo公司排名教程
  • 网站建设银行品牌全案策划
  • 可在哪些网站做链接大数据精准营销案例
  • 官方百度整站快速排名优化