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

人力资源三网站建设跨境电商一件代发货源平台

人力资源三网站建设,跨境电商一件代发货源平台,北京互联网金融公司排名,北京城乡建设集团有限公司官网1 两种非递归实现 在前面我们解决无向图的单点通性和单点路径问题时,都用到了深度优先搜索算法。深度优先搜索算法可以用递归和非递归两种方式。这里讨论非递归实现。 无向图结构使用邻接表实现。 第一种非递归方法(推荐),代码如…

1 两种非递归实现

在前面我们解决无向图的单点通性和单点路径问题时,都用到了深度优先搜索算法。深度优先搜索算法可以用递归和非递归两种方式。这里讨论非递归实现。

无向图结构使用邻接表实现。

  • 第一种非递归方法(推荐),代码如下:

    •       private void dfs() {// 栈记录搜索路径Stack<Iterator<Integer>> path = new Stack<>();// marked[v] = true;if (!marked[s]) {// 起点未标记,标记计数加1// 起点默认没标记,可以不加是否标记判断marked[s] = true;count++;Iterable<Integer> iterable = graph.adj(s);Iterator<Integer> it;if (iterable != null && (it = iterable.iterator()) != null){// 顶点对应的邻接表迭代器存入栈path.push(it);}}while (!path.isEmpty()) {Iterator<Integer> it = path.pop();int x;while (it.hasNext()) {// 邻接表迭代器有元素,获取元素x = it.next();if (!marked[x]) {// 顶点未被标记,标记计数+1marked[x] = true;count++;if (it.hasNext()) {// 邻接表迭代器有元素重新入栈path.push(it);}// 深度优先原则,当前迭代器入栈,新标记顶点的邻接表迭代器入栈,下次循环优先访问Iterable<Integer> iterable = graph.adj(x);if (iterable != null && (it = iterable.iterator()) != null){path.push(it);}break;}}}}
      
    • 算法分析参考0103深度优先搜索和单点连通-无向图-数据结构和算法(Java)

  • 第二种非递归实现,实现如下

    •   private void  dfsDel() {// 支持后入先出和任意删除java.util.Stack<Integer> stack = new java.util.Stack<>();stack.push(s);while (!stack.isEmpty()) {int v = stack.peek();if (!marked[v]) {marked[v] = true;count++;for (int w : graph.adj(v)) {// 访问同层顶点if (!marked[w]) {// 没被标记过顶点,入栈if (stack.contains(w)) {// 没被标记,但是已经入栈,说明之前是同层压入,需要移除重新压入// 这样符合深度优先原则stack.removeElement(w);}stack.push(w);}}}else {// 顶点v的邻接顶点都已访问完毕,弹出顶点v,回溯stack.pop();}}}
      
    • 栈除了满足后入先出规则外,还必须支持删除任意元素的操作

2 对比分析

  • 栈结构
    • 第一种用到的栈为标准栈,实现后入先出,结构简单,可以到仓库里面搜索栈源码。
    • 第二种栈除了满足后入先出规则外,还必须支持删除任意元素的操作
  • 深度优先的实现:
    • 第一种栈存储邻接表迭代器 ,用于访问邻接表顶点(同层),算法会优先访问下一层的顶点而不是同层的后继顶点。
    • 第二种存储顶点。优先存储邻接表中所有顶点(同层),在访问下一层顶点时,如果顶点未被标记但是在栈中存在,通过先删除在重入入栈,保证深度优先。
  • 性能分析:
    • 相同点:搜索标记与起点连通的所有顶点所需时间和顶点的度数之和成正比
    • 无向图顶点多边多,某个起点对应的深度很深的情况下,第二种结构在没有回溯之前,栈中会存储大量的顶点元素,那么判断顶点是否在栈中以及删除顶点最坏情况下需要时间复杂度为O(度数之和);第一种栈中存储邻接表迭代器,每个顶点对应一个,最坏情况下时间复杂度为O(顶点数)
  • 两种算法在单点连通(250个顶点 1273条边)情况下时间消耗:
    • 第一种:2-3ms
    • 第二种:7-8ms

当然第二种栈我们直接用的java.util.Stack,如果自定义实现后入先出规则+任意删除,性能会更好些。

后记

如果小伙伴什么问题或者指教,欢迎交流。

❓QQ:806797785

⭐️源代码仓库地址:https://gitee.com/gaogzhen/algorithm

参考链接:

[1][美]Robert Sedgewich,[美]Kevin Wayne著;谢路云译.算法:第4版[M].北京:人民邮电出版社,2012.10.p342-344.

http://www.yayakq.cn/news/244845/

相关文章:

  • 网站备案号如何获得南通宏仁建设工程有限公司招聘网站
  • 做效果图比较好的模型网站建设电影网站代码
  • 郑州高新区建设环保局网站关键词seo排名怎么样
  • 自己做视频网站会不会追究版权wordpress 设置语言
  • 优化网站排名方法建设公司网站需要钱吗
  • 域名还在备案可以做网站吗网页制作公司广州
  • 本地做的网站怎么放到网上去英语培训
  • 网站开发建设费用明细如何制作出优秀的ui设计
  • 上饶网站建设兼职手机网站微信登录接口
  • 长沙网站推广seo响应式网站和非响应式网站的区别
  • 行知网站建设公司公众号运营方案
  • 广西教育学会 网站建设人工智能设计网站
  • 网站建设怎么制作模板兰州装修公司口碑排名
  • 建设局网站买卖合同单页网站制作 在线 支付
  • 怎样发布自己的网站动漫设计与制作培训学院
  • 学习网站后台维护网站建设带主机
  • 建设银行网站可以查保单吗电气营销型网站方案
  • 图书馆门户网站建设方案专门做超市海报的网站
  • 中交建设集团网站更改wordpress所有的链接
  • 网站开发公司职位做一件代发的网站
  • 企业专业网站建设的必要性做网站从设计到上线流程
  • 一 网站建设的总体目标微信小程序开发案例教程
  • 大型网站维护费用官方网站拼多多
  • 那个网站做二手买卖的网络营销中的seo与sem
  • 网站开发用到的虚拟机有哪些手机网站适合分开做
  • 蚌埠网站制作公司哪家好南京行业网站建设
  • 河北网站建设模板网站开发与兼容模式
  • 专业制作网站报价网站搭建一般要多少钱
  • 哪些网站做外链建设官方网站需要注意什么
  • 企业网站开发课程培训门户网站开发过程