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

网站外链接自己可以怎么做的标书制作公司

网站外链接自己可以怎么做的,标书制作公司,wordpress替代,网站建设知名这题是一道比较典型的bfs,但是题目会在此基础上加一些限制,先给出示例和图示让大家更容易理解这题的思路 输入:moveTime [[0,4],[4,4]]输出:6解释:需要花费的最少时间为 6 秒。- 在时刻 t 4,从房间 (0, …

这题是一道比较典型的bfs,但是题目会在此基础上加一些限制,先给出示例和图示让大家更容易理解这题的思路

输入:moveTime = [[0,4],[4,4]]输出:6解释:需要花费的最少时间为 6 秒。- 在时刻 t == 4,从房间 (0, 0) 移动到房间 (1, 0) ,花费 1 秒。
- 在时刻 t == 5 ,从房间 `(1, 0)` 移动到房间 (1, 1) ,花费 1 秒。

典型的bfs只是要边bfs的时候边判断t是需要wait后加1还是直接加1,对于此题我们不仅仅可以使用bfs也可以使用Dijkstra,Dijkstra的逻辑感可能更强些,但是会用到一个我平常不怎么使用的函数式子。

先来看看Dijkstra的示例实现,分步说说刚好巩固自身对于该方法的使用,因为我也不太熟悉。

先建立上、下、左、右的走步坐标系

int[][] dirs = {{-1, 0}, {1, 0}, {0, -1}, {0, 1}};

然后建立队列存放数据,但这个队列有些不同,它不是先进先出(FIFO)类型的队列,而是根据数组第一个值的大小决定,最小的值先出栈

PriorityQueue<int[]> heap = new PriorityQueue<>((a, b) -> a[0] - b[0]);

这里解释很简单,就是初始化一下坐标的开始位置{t,x,y},t表示抵达(x,y)位置的时间,将这三个值一起记录下来方便遍历比较

heap.offer(new int[]{0, 0, 0});

这里的话算是一种打标记,记录每个位置的抵达时间,如果有比初始的值小的就替换然后进栈遍历后续节点

int n = moveTime.length, m = moveTime[0].length;
// time[i][j]表示到达(i,j)的最少时间
int[][] time = new int[n][m];
for (int i = 0; i < n; i++) {Arrays.fill(time[i], Integer.MAX_VALUE);
}
time[0][0] = 0; // 初始化

这里就是Dijkstra最关键的一个部分,先来解释一下这里的代码,将初始节点和后续节点抛出(选取最小的t节点)对于t>time[x][y]的值是因为之前遍历过了(x,y)这个节点且其对应的抵达时间相较于当前的t更小,所以不需要继续往下了
举个例子:
假设当前到 (1,1) 有两条路径:

  • 一条需要时间 10,先入队。

  • 后来发现另一条更优路径,时间为 6,也入队。

此时队列中两个 (1,1)

[ (6, 1, 1), (10, 1, 1) ]
  • 6 的那条先处理,更新时间为 6

  • 再处理 10 的那条,因为你之前已经更新为 6,所以直接跳过。

    if (t > time[x][y]) continue; // 剪枝

如果不剪枝会怎么样?

  • 会再次访问 (1,1),重复处理邻居,导致不必要的入队操作,性能变差。
while (!heap.isEmpty()) {int[] curr = heap.poll();int t = curr[0], x = curr[1], y = curr[2];if (t > time[x][y]) { // 剪枝continue;}for (int[] dir : dirs) {int nx = x + dir[0], ny = y + dir[1];if (0 <= nx && nx < n && 0 <= ny && ny < m) {int nt;if (t < moveTime[nx][ny]) { // 需要等待nt = 1 + moveTime[nx][ny];} else { // 否则,直接进入nt = t + 1;}if (nt < time[nx][ny]) { // 当前的更优路径time[nx][ny] = nt;heap.offer(new int[]{nt, nx, ny});}}}}

之后就是进入bfs的遍历进行判断当前节点向四周延申的节点是需要等待后才能进入还是可以直接进入,并更新路径time[nx][ny],以便后续的节点遍历至相同节点进行对比抵达时间然后更新。

最后return time[n-1][m-1]即可

以下是完整代码

class Solution {public int minTimeToReach(int[][] moveTime) {// Dijkstra,并允许同一个节点的重复访问int[][] dirs = {{-1, 0}, {1, 0}, {0, -1}, {0, 1}};// 最小堆,存储数组 {t, x, y},表示到达 (x, y) 的时间为 tPriorityQueue<int[]> heap = new PriorityQueue<>((a, b) -> a[0] - b[0]);// 起点heap.offer(new int[]{0, 0, 0});int n = moveTime.length, m = moveTime[0].length;// time[i][j]表示到达(i,j)的最少时间int[][] time = new int[n][m];for (int i = 0; i < n; i++) {Arrays.fill(time[i], Integer.MAX_VALUE);}time[0][0] = 0; // 初始化while (!heap.isEmpty()) {int[] curr = heap.poll();int t = curr[0], x = curr[1], y = curr[2];if (t > time[x][y]) { // 剪枝continue;}for (int[] dir : dirs) {int nx = x + dir[0], ny = y + dir[1];if (0 <= nx && nx < n && 0 <= ny && ny < m) {int nt;if (t < moveTime[nx][ny]) { // 需要等待nt = 1 + moveTime[nx][ny];} else { // 否则,直接进入nt = t + 1;}if (nt < time[nx][ny]) { // 当前的更优路径time[nx][ny] = nt;heap.offer(new int[]{nt, nx, ny});}}}}return time[n - 1][m - 1]; // 终点}
}

这是用了方法优先队列对此题的优解,也可以使用传统的bfs队列,只是会时间用的更长一些

class Solution {public int minTimeToReach(int[][] moveTime) {int n = moveTime.length, m = moveTime[0].length;int[][] dirs = {{0, 1}, {1, 0}, {0, -1}, {-1, 0}};// 初始化距离矩阵int[][] dist = new int[n][m];for (int i = 0; i < n; i++) {Arrays.fill(dist[i], Integer.MAX_VALUE);}dist[0][0] = 0;// 使用双端队列进行BFSDeque<int[]> q = new ArrayDeque<>();q.offer(new int[]{0, 0});while (!q.isEmpty()) {int[] curr = q.poll();int i = curr[0], j = curr[1];for (int[] dir : dirs) {int ni = i + dir[0], nj = j + dir[1];if (ni >= 0 && ni < n && nj >= 0 && nj < m) {// 计算从(i,j)到达(ni,nj)的最早时间int newTime = Math.max(dist[i][j], moveTime[ni][nj]) + 1;// 如果找到更优路径,更新并加入队列if (newTime < dist[ni][nj]) {dist[ni][nj] = newTime;q.offer(new int[]{ni, nj});}}}}return dist[n - 1][m - 1];}
}

也一样需要一个二维数组去存抵达时间的值,然后更新最小的抵达时间,这个应该比上一个更容易理解,不想再解释了…


文章转载自:

http://GtsLfYO4.jfbbq.cn
http://SJKySIAn.jfbbq.cn
http://ekNGxymV.jfbbq.cn
http://FCL3ULg7.jfbbq.cn
http://VCIhi3ie.jfbbq.cn
http://g0JJnrBT.jfbbq.cn
http://WfSXubkL.jfbbq.cn
http://0Vdh1idn.jfbbq.cn
http://2j28E0sE.jfbbq.cn
http://xB2nJZPx.jfbbq.cn
http://Mdm4adSA.jfbbq.cn
http://9tee71td.jfbbq.cn
http://SBu034VT.jfbbq.cn
http://Vz5NxKrU.jfbbq.cn
http://QUk2vcmF.jfbbq.cn
http://LaDp14JI.jfbbq.cn
http://XKfxwBt3.jfbbq.cn
http://wnJGyz7V.jfbbq.cn
http://Y4rpciKJ.jfbbq.cn
http://5T8q0qBi.jfbbq.cn
http://EaNf4yUN.jfbbq.cn
http://tzaC2Eis.jfbbq.cn
http://mF6pTNyG.jfbbq.cn
http://3Aln6feA.jfbbq.cn
http://UFBRAkTf.jfbbq.cn
http://8MZ5PBXH.jfbbq.cn
http://dmeLV4QS.jfbbq.cn
http://EGwJlWWT.jfbbq.cn
http://jEnONPJE.jfbbq.cn
http://wmufRkWG.jfbbq.cn
http://www.dtcms.com/wzjs/625922.html

相关文章:

  • 网站照片如何处理深圳建网站兴田德润专业
  • 厦门图书馆网站建设上海品质网站建设
  • 购物商城网站建设公司做的时间长的网站制作公司哪家好
  • 海城网站制作建设最好的搭建网页的平台
  • 网上服装商城网站建设方案策划上海闵行区
  • 达州北京网站建设dz论坛如何seo
  • 网站301了不知道在哪做的企业形象设计公司
  • 网站栏目规划图网络品牌推广方法有哪些
  • 南宁保洁网站建设土建网招聘信息
  • 企业网站开发开题报告网站结合微信
  • 玩具网站 下载wordpress留言机器人
  • 曲靖手机网站建设用wordpress建公司网站步骤
  • 福州做公司网站wordpress ui psd
  • 室内设计图网站有哪些个人网站域名取名
  • 想见你一个网站怎么做深圳网站制作济南
  • 做网站需要哪些手续起飞页 wordpress
  • 谷歌seo推广招聘八方资源网做网站优化怎么样
  • 大连手机网站制作课程建设网站
  • 微信网站作用jsp做手机网站
  • 凡科网免费做网站企业组网解决方案
  • 芜湖网站建设芜湖中国做视频网站有哪些
  • 南京网站备案代码模版 网站
  • 如何备份网站的中标查询
  • 做平面vi网站如何注册企业邮箱?
  • 网站打不开了怎么办什么是网络营销行为分析
  • 优化网站浏览量怎么看wordpress 用户组
  • 深圳外贸网站建设服务商阿里云 拦截网站
  • 网站开发售后工作中国专利查询系统入口
  • 沧州哪里做网站北京城市雕塑建设管理办公室网站
  • 汽车网站建设流程图阿里巴巴运营岗位