当前位置:网站首页 > 深度学习 > 正文

广度优先搜索和深度优先搜索的优缺点(深度与广度优先搜索)



广度优先搜索和深度优先搜索各有他的优点,也有他们的不足之处。
广度优先搜索在遍历的时候不需要全部遍历,搜索到符合条件的就立即终止,这样就不会浪费太多时间。但是在遍历的过程中,他需要创建一个队列来保存遍历的状态(也就是遍历到的每一个结点需要先存入到队列中,然后取出),这样就无非就增加了空间复杂度。
而深度优先搜索则会遍历所有的结点,不需要保存遍历的状态,虽然时间复杂度高但是空间复杂度低。在使用深度优先搜索的时候非常容易超时,因为每次遍历时间复杂度都是以指数的形式增长的。所以我们在使用深度优先搜索的时候我们一般都会联合奇偶剪枝一起使用,这样就极大的降低了深度优先搜索的时间复杂度。
奇偶剪枝:奇偶剪枝就是在你遍历的过程中,首先判断你这个结点能不能按要求到达目的地,如果能,则访问他的邻结点,否则,退出这一层遍历。
部分内容来自:https://blog.csdn.net/chyshnu/article/details/
把矩阵看成如下形式:
0 1 0 1 0 1
1 0 1 0 1 0
0 1 0 1 0 1
1 0 1 0 1 0
0 1 0 1 0 1
从为 0 的格子走一步,必然走向为 1 的格子 。
从为 1 的格子走一步,必然走向为 0 的格子 。
即:
从 0 走向 1 必然是奇数步,从 0 走向 0 必然是偶数步。

 

一般深度优先搜索用来解那种需要得到全部解的题,而广度优先搜索则是用来求最短路径的,到达的每一个结点都是最短路径。

到此这篇广度优先搜索和深度优先搜索的优缺点(深度与广度优先搜索)的文章就介绍到这了,更多相关内容请继续浏览下面的相关推荐文章,希望大家都能在编程的领域有一番成就!

版权声明


相关文章:

  • 微信小程序学习笔记-(9)-仿智行火车票2024-12-29 11:36:09
  • 微信小程序学习笔记-(10)-猫眼电影案例2024-12-29 11:36:09
  • webpack5学习与实战-(一)-webpack的初步认识2024-12-29 11:36:09
  • webpack5学习与实战-(三)-引入其他资源模块2024-12-29 11:36:09
  • webpack5学习与实战-(五)-直接加载资源2024-12-29 11:36:09
  • webpack5学习与实战-(七)-代码分离2024-12-29 11:36:09
  • 广度优先搜索和深度优先搜索都属于什么算法(广度优先搜索序列和深度优先搜索序列)2024-12-29 11:36:09
  • 广度优先搜索和深度优先搜索的区别(广度优先搜索和深度优先搜索的区别和联系)2024-12-29 11:36:09
  • 广度优先搜索和深度优先搜索(广度优先搜索和深度优先搜索的基本思想)2024-12-29 11:36:09
  • 广度优先搜索和深度优先搜索都可以用于遍历一棵树(广度优先搜索序列和深度优先搜索序列)2024-12-29 11:36:09
  • 全屏图片