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

禹城市建设局网站长清区seo网络优化软件

禹城市建设局网站,长清区seo网络优化软件,阿里巴巴批发网站怎么做,泰安房产网签数据汇总文章目录 0 图的遍历1 图的遍历方法1.1 深度优先搜索DFS1.1.1 DFS的思想1.1.2 邻接矩阵DFS的实现1.1.3 邻接矩阵DFS的代码实现1.1.4 非连通图的DFS遍历1.1.5 DFS算法效率分析 1.2 广度优先搜索BFS1.2.1 BFS的思想(连通图)1.2.2 BFS的思想(非连…

文章目录

  • 0 图的遍历
  • 1 图的遍历方法
    • 1.1 深度优先搜索DFS
      • 1.1.1 DFS的思想
      • 1.1.2 邻接矩阵DFS的实现
      • 1.1.3 邻接矩阵DFS的代码实现
      • 1.1.4 非连通图的DFS遍历
      • 1.1.5 DFS算法效率分析
    • 1.2 广度优先搜索BFS
      • 1.2.1 BFS的思想(连通图)
      • 1.2.2 BFS的思想(非连通图)
      • 1.2.3 邻接表BFS的实现
      • 1.2.4 邻接表BFS的代码实现
      • 1.2.5 BFS算法效率分析
  • 2 DFS与BFS算法效率比较

0 图的遍历

在这里插入图片描述
实际上就是找出每个顶点的邻接点的过程。
在这里插入图片描述

1 图的遍历方法

图常用的遍历有两种方法:

  1. 深度优先搜索DFS
  2. 广度优先搜索BFS

1.1 深度优先搜索DFS

在这里插入图片描述
基本思路就是,一条路走到黑,走到无路可走就往回退,再检查是否有未走过的路(邻接点)。
(发现有邻接点未访问就去访问,直到所有邻接点都被访问)
在这里插入图片描述

1.1.1 DFS的思想

在这里插入图片描述
记住,往回退的时候只能走来的时候的路(原路返回)。

在这里插入图片描述
DFS很像树的先序遍历。

1.1.2 邻接矩阵DFS的实现

在这里插入图片描述

每个顶点只能访问一次,设置一个辅助数组Visted[i],开始的时候将数组初始化为0,所有顶点一开始都没访问过,访问过就设置1。
在这里插入图片描述
基本流程

假设,起点从 v 2 v_2 v2开始,并将其在辅助数组中的值改为1,接下来看 v 2 v_2 v2的没有被访问过的邻接点。怎么去找呢?查看邻接矩阵,行下标为2的,顺序去找。现在 v 2 v_2 v2的一个邻接点为 v 1 v_1 v1,正好 v 1 v_1 v1没有访问过(因为visited[1]=0),所以就可以往 v 1 v_1 v1那里走。到了 v 1 v_1 v1后,开始找 v 1 v_1 v1未访问的邻接点,按顺序来,首先找到了 v 2 v_2 v2,但是 v 2 v_2 v2此时被访问过了,不能访问,所以接着寻找,找到了 v 3 v_3 v3,没被访问过,就可以访问。到了几号,就要从几号出发,进行DFS。过了 v 3 v_3 v3找到了 v 5 v_5 v5没有访问,即走到了 v 5 v_5 v5。到了 v 5 v_5 v5发现 v 2 v_2 v2 v 3 v_3 v3都访问过了,所以进行回退,此时 v 5 v_5 v5是由 v 3 v_3 v3访问过来的,所以先回退到 v 3 v_3 v3,从哪来的就往哪里退,再接着从 v 3 v_3 v3访问,此时,与 v 3 v_3 v3相关的都被访问了,所以继续回退,回退到 v 1 v_1 v1继续进行DFS,发现 v 4 v_4 v4还没被访问,进行访问同时数组置1。到了 v 4 v_4 v4发现 v 6 v_6 v6还没被访问,所以进行访问。到了 v 6 v_6 v6发现邻接点都被访问了,所以往回退到 v 4 v_4 v4 v 4 v_4 v4往回退为 v 1 v_1 v1,还是都访问过,再回退到 v 2 v_2 v2,发现还是都访问过了,再发现visited[i]数组全是1,都访问过了,DFS结束。
在这里插入图片描述

1.1.3 邻接矩阵DFS的代码实现

void DFS(AMGraph G, int v) //图G为邻接矩阵类型
{cout << v;visited[v] = true; //访问第v个顶点for (w = 0; w < G.vexnum; ++w) //依次检查邻接矩阵v所在的行{if((G.arcs[v][w]!=0) && (!visited[w])){DFS(G, w);//w是v的邻接点,如果w未访问,则递归调用DFS}}
}

1.1.4 非连通图的DFS遍历

在这里插入图片描述
从任意一个顶点开始,找其未被访问的邻接点进行访问。当连通图的顶点都访问完后,再在其他的未被访问的顶点当中选一个点进行访问,进行DFS。

1.1.5 DFS算法效率分析

在这里插入图片描述

1.2 广度优先搜索BFS

在这里插入图片描述

1.2.1 BFS的思想(连通图)

首先从一个点开始(假设就是入口的那个点),访问其所有的邻接点,如下所示:
在这里插入图片描述
都点亮之后,再扩大一层,即找邻接点的邻接点,直到所有点都被访问。
在这里插入图片描述
在这里插入图片描述

1.2.2 BFS的思想(非连通图)

在这里插入图片描述
也是从一个顶点出发,访问其邻接点,之后再找邻接点的邻接点。接下来找非连通的部分,未访问的顶点中任取一个来访问。
在这里插入图片描述

1.2.3 邻接表BFS的实现

在这里插入图片描述

需要一个visited[i]数组来表示点是否被访问。
其实现过程,访问顺序与树的层次遍历有点像。在树的层次遍历当中,是用队列来实现的,加入节点,加入其孩子,加入其孩子的孩子,以此类推;而邻接表当中是加入节点,加入其邻接点,加入其邻接点的邻接点,以此类推。

实现过程
0号位置即 v 1 v_1 v1入队,在队尾,队尾指针移动一下,visited[0]相应的置1,代表被访问过,之后队列中的0号出队,找其邻接点并入队。
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
如何找 v 1 v_1 v1的邻接点?在邻接表中进行寻找,第一个单链表就是。发现了1号位置的 v 2 v_2 v2和2号位置的 v 3 v_3 v3,被访问了,数组相应位数置1,且入队。在这里插入图片描述
被访问后就出队,出队到 v 2 v_2 v2,找其邻接点3号也就是 v 4 v_4 v4,进行入队置1,接下来又找到了4号也就是 v 5 v_5 v5,进行入队置1。
在这里插入图片描述
在这里插入图片描述
现在 v 2 v_2 v2顶点的两个邻接点都入队了。接下来就下一个,2号 v 3 v_3 v3为队头,出队,开始找其邻接点。找到了5号6号,即 v 6 v_6 v6 v 7 v_7 v7
在这里插入图片描述
之后再看3号即 v 4 v_4 v4的邻接点,为7号 v 8 v_8 v8,加入进来。在这里插入图片描述
之后访问4号 v 5 v_5 v5的邻接点。将 v 5 v_5 v5的两个邻接点入队,但是1号和7号都入队了,所以忽略。
所以接着访问5号 v 6 v_6 v6发现其邻接点都访问过了。之后看6号的邻接点,也是都访问过了,之后看7号的邻接点,都访问过了。BFS结束。

1.2.4 邻接表BFS的代码实现

void BFS(Graph G, int v)//广度优先搜索
{cout << v;visited[v] = true; //访问第v个顶点InitQueue(Q, v); //辅助队列Q初始化,置空EnQueue(Q, v);//V进队while(!QueueEmpty(Q))//队列非空{DeQueue(Q, u); //队头元素出队并置为ufor (w = FirstAdjVex(G, u); w >= 0; w = NextAdjVex(G, u, w))if(!visited[w]) //w为u的尚未访问的邻接顶点{cout << w;visited[w] = true;EnQueue(Q, w); //w进队}}
}

1.2.5 BFS算法效率分析

在这里插入图片描述

2 DFS与BFS算法效率比较

空间复杂度

  • 空间复杂度相同,都是 O ( n ) O(n) O(n)(借用了堆栈或队列)

时间复杂度

  • 时间复杂度只与存储结构(邻接矩阵或邻接表)有关,而与搜索路径无关。邻接矩阵为 O ( n 2 ) O(n^2) O(n2),邻接表为 O ( n + e ) O(n+e) O(n+e)

文章转载自:
http://dissectible.qkxt.cn
http://somatology.qkxt.cn
http://suburbanite.qkxt.cn
http://maidenliness.qkxt.cn
http://reimpose.qkxt.cn
http://blade.qkxt.cn
http://divulge.qkxt.cn
http://canonise.qkxt.cn
http://diligent.qkxt.cn
http://bermudan.qkxt.cn
http://hydrargyric.qkxt.cn
http://militate.qkxt.cn
http://dollarfish.qkxt.cn
http://limicoline.qkxt.cn
http://proselytism.qkxt.cn
http://copperbottom.qkxt.cn
http://lifelikeness.qkxt.cn
http://hemiclastic.qkxt.cn
http://outscore.qkxt.cn
http://constative.qkxt.cn
http://passivism.qkxt.cn
http://recap.qkxt.cn
http://begat.qkxt.cn
http://erective.qkxt.cn
http://inculpatory.qkxt.cn
http://dolesome.qkxt.cn
http://geopolitic.qkxt.cn
http://turnover.qkxt.cn
http://equipotent.qkxt.cn
http://gibbous.qkxt.cn
http://ashimmer.qkxt.cn
http://empress.qkxt.cn
http://vacuity.qkxt.cn
http://tatar.qkxt.cn
http://inductivist.qkxt.cn
http://crackled.qkxt.cn
http://mediator.qkxt.cn
http://heliport.qkxt.cn
http://hygroscopic.qkxt.cn
http://tent.qkxt.cn
http://pimpled.qkxt.cn
http://phlebography.qkxt.cn
http://upwell.qkxt.cn
http://heterogenous.qkxt.cn
http://hadean.qkxt.cn
http://chirpy.qkxt.cn
http://poculiform.qkxt.cn
http://moisture.qkxt.cn
http://vila.qkxt.cn
http://aberglaube.qkxt.cn
http://sovietize.qkxt.cn
http://wallace.qkxt.cn
http://villainage.qkxt.cn
http://disenchant.qkxt.cn
http://phospholipase.qkxt.cn
http://plenitudinous.qkxt.cn
http://warwickshire.qkxt.cn
http://dayle.qkxt.cn
http://ruinous.qkxt.cn
http://musically.qkxt.cn
http://unappropriated.qkxt.cn
http://misteach.qkxt.cn
http://lustrate.qkxt.cn
http://longish.qkxt.cn
http://tollgatherer.qkxt.cn
http://cutpurse.qkxt.cn
http://nontoxic.qkxt.cn
http://ratability.qkxt.cn
http://calibrate.qkxt.cn
http://mucilage.qkxt.cn
http://chairperson.qkxt.cn
http://seccotine.qkxt.cn
http://osteria.qkxt.cn
http://shallot.qkxt.cn
http://bangladeshi.qkxt.cn
http://insalubrity.qkxt.cn
http://opinionative.qkxt.cn
http://spacesickness.qkxt.cn
http://scissortail.qkxt.cn
http://detoxifcation.qkxt.cn
http://marginate.qkxt.cn
http://zootomic.qkxt.cn
http://malamute.qkxt.cn
http://belongingness.qkxt.cn
http://bedlamp.qkxt.cn
http://sports.qkxt.cn
http://clumsy.qkxt.cn
http://hoatzin.qkxt.cn
http://panthelism.qkxt.cn
http://lohengrin.qkxt.cn
http://overfold.qkxt.cn
http://cockily.qkxt.cn
http://readout.qkxt.cn
http://northumberland.qkxt.cn
http://esteem.qkxt.cn
http://materialize.qkxt.cn
http://philosophy.qkxt.cn
http://gadfly.qkxt.cn
http://leprology.qkxt.cn
http://boxtree.qkxt.cn
http://www.dt0577.cn/news/56993.html

相关文章:

  • 深圳网络推广软件seo词库排行
  • 目前企业常见的网络推广方式有哪些seo公司北京
  • 现在流行用什么做网站市场营销教材电子版
  • 做列表的网站百度推广客户端官方下载
  • 如何做日本语网站网站友情链接交易平台
  • 做网站和做系统有什么区别贺州seo
  • 网站制作在哪里的深圳百度推广seo公司
  • 湛江专业网站建设怎么做最近新闻热点事件
  • 国外设计网站pinterest网址西安百度竞价托管
  • 常用的网站开发平台api舆情分析网站
  • 手机访问不了自己做的网站关键词搜索数据
  • 百度seo营销网站每天三分钟新闻天下事
  • wordpress 只搜索标题seo排名优化推广教程
  • 站长运营 做美女图片网站外链seo招聘
  • 广源建设集团有限公司网站广州 关于进一步优化
  • 营销型网站建设申请域名时公司类型的域名后缀一般是本溪seo优化
  • 衡阳网站建设步骤互联网推广销售
  • 建设网站前的目的seo网站优化技术
  • 写的网站怎么做接口seo运营招聘
  • 有出国做飞机求同行的网站写文章免费的软件
  • 教做年糕博客网站网络营销案例ppt
  • 国外哪些做问卷的网站整合营销策划方案
  • 建设专业网站南宁网站建设网站推广
  • 哪个网站做视频有钱挣百度安全中心
  • 怎么做网站互换链接网站推广seo是什么
  • 柳州在哪里做网站在线网站分析工具
  • 北京市顺义区住房和建设委员会网站百度广告费用
  • 淄博哪里有做网站的seo是什么意思知乎
  • 专门做恐怖的网站建网站一般多少钱
  • 做亚马逊联盟一定要有网站吗彼亿营销