博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
cf 442 D. Olya and Energy Drinks
阅读量:6546 次
发布时间:2019-06-24

本文共 521 字,大约阅读时间需要 1 分钟。

(bfs)

题意:

给一张\(n \times m(n <= 1000,m <= 1000)\)的地图

给出一个起点和终点,每秒钟可以沿着四个方向直走\(1\)到$k(k <= 1000) $步,问从起点到终点最少需要多少秒

思路:

最暴力的\(bfs\)时间复杂度为\(O(n * m * k)\)

由bfs可以知道,每个点只需要被访问过一点就已经是最短了,也即访问过一次就可以将其从地图中删去了

  • 这里有两种方法可以来实现
    1、用set来维护每行每列的点,从set中查找出当前点四个方向最近的点 判断距离是否超过k,更新完之后再从set中删点
    这样的时间复杂度为\(O(n * m * log(n))\)
    2、用并查集缩点来维护四个方向上最近的未更新过的点 复杂度会比第一种低一些

我们知道每个点只可能被四个方向更新,那么我们用状压维护每个点是被哪些方向更新的

从当前点开始更新某个方向上的点,如果更新的点在这个方向上已经更新过了,显然就可以跳出更新了,因为这个方向上后面的点一定也更新过了。复杂度\(O(4 * n * m)\)

转载于:https://www.cnblogs.com/jiachinzhao/p/7735829.html

你可能感兴趣的文章
洛谷P1287 盒子与球 数学
查看>>
Bootstrap vs Foundation如何选择靠谱前端框架
查看>>
与、或、异或、取反、左移和右移
查看>>
vue常用的指令
查看>>
matlab练习程序(随机游走图像)
查看>>
Linux命令行下运行java.class文件
查看>>
input文本框实现宽度自适应代码实例
查看>>
protocol buffers的编码原理
查看>>
行为型设计模式之命令模式(Command)
查看>>
减少死锁的几个常用方法
查看>>
HDFS 核心原理
查看>>
正确配置jstl的maven依赖,jar包冲突的问题终于解决啦
查看>>
登录内网账号后,连接不上内网网址
查看>>
安装 MariaDB
查看>>
java 为啥变量名前要加个m?
查看>>
探索Android中的Parcel机制(上)
查看>>
C#开发微信门户及应用(5)--用户分组信息管理
查看>>
怎样实现前端裁剪上传图片功能
查看>>
ffmpeg+SDL2实现的视频播放器「退出、暂停、播放」
查看>>
2011/7/3 第二次评审
查看>>