cf 442 D. Olya and Energy Drinks(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)\)

最新文章

  1. QString 和std::string互转
  2. Java垃圾收集算法介绍
  3. 高德地图API应用
  4. [codevs1073]家族
  5. 阿里云OSS存储开发(一)
  6. 【COGS1049】天空中的繁星
  7. 交叉编译:cannot find /lib/libc.so.6 collect2: ld returned 1 exit status
  8. linux内核参数调优,缓冲区调整,tcp/udp连接管理,保持,释放优化,gossary,terms
  9. evernote
  10. [补档][Hnoi2013]游走
  11. (转)sizeof()和_countof()区别
  12. 磁盘IO的性能指标 阻塞与非阻塞、同步与异步 I/O模型
  13. RPA简介
  14. shell脚本:通过域名获取证书的过期时间
  15. Java通过BCrypt加密
  16. GIS案例学习笔记-明暗等高线提取地理模型构建
  17. jQuery 向另一个页面传参,同时跳转到该页面
  18. 第09章:MongoDB-CRUD操作--文档--修改--update
  19. IDEA的强大
  20. 数据库与sql注入的相关知识

热门文章

  1. 第一次使用Git上传本地项目到github
  2. 让CPU使用率正弦变化
  3. golang的加法比C快?
  4. JavaSE基础复习---Class类与反射机制
  5. 嵌入式框架Zorb Framework搭建四:状态机的实现
  6. SPFA算法(2) POJ 1511 Invitation Cards
  7. js倒计时页面跳转
  8. Django-modelfrom组件
  9. CCS实例,网页栏目
  10. oracle 游标例子