算法导论复习——CHP22 基本图算法

news2025/5/25 12:06:01

图的表示        

        邻接矩阵和邻接表

        稀疏图一般用邻接表表示(稀疏图:边数|E|远小于|V|^2的图 )

        稠密图更倾向于用邻接矩阵表示 (稠密图:边数|E|接近|V|^2的图)

        邻接矩阵可用于需要快速判断任意两个结点之间是否有边相连的应用场景。

        如果用邻接表表示,为判断一条边(u,v)是否是图中的边,需要在邻接链表Adj[u]中搜索,效率较低。

图的检索和周游

        被检测:在图中,当某结点的所有邻接结点都被访问了时, 称该结点被检测了。

        经典的图检索算法:

  •         宽度优先搜索(BFS)

  1. 从结点v开始,首先访问结点v,给v标上已访问标记。
  2. 访问邻接于v且目前尚未被访问的所有结点,此时结点v被 检测,而v的这些邻接结点是新的未被检测的结点。将这些结点依次放置到一个称为未检测结点表的队列中。
  3. 若未检测结点表为空,则算法终止;
  4. 否则,取未检测结点表的表头结点作为下一个待检测结点,重复上述过程。直到Q为空,算法终止。

        设t(n,e)和s(n,e)是算法BFS在任一具有n个结点和 e 条边的图G上所花的时间和附加空间。         若G由邻接表表示,则 t(n,e)=Θ(n+e) 和 s(n,e)=Θ(n)。

        若G由邻接矩阵表示,则 t(n,e)=Θ(n^2) 和 s(n,e)=Θ(n) 

  •         深度优先检索(DFS)

        ① DFS可以访问由v可到达的所有结点

        ② 如果t(n,e)和s(n,e)表示DFS对一n结点e条边的图所花的时间和附加空间,则

                s(n,e)=Θ(n)  

                t(n,e)= Θ(n+e) G采用邻接表表示 

                t(n,e)= Θ(n^2) G采用邻接矩阵表示        

图周游算法的应用

        判定图G的连通性:若调用BFS的次数多于1次,则G 为非连通的。

        生成图G的连通分图:一次调用BFS中所访问到的所 有结点及连接这些结点的边构成一个连通分图。 

宽度优先生成树

        向前边:BFS中由 u 到达未访问结点w的边(u,w)。

        宽度优先生成树: 记T是BFS中处理的所有向前边集合。 若G是连通图,则BFS终止时,T构成一棵生成树,称为图G的宽度优先生成树。

         修改算法BFS:

 

深度优先周游算法DFT

        反复调用DFS,直到所有结点均被检测到。

        应用:

        ① 判定图G的连通性

        ② 连通分图

        ③ 无向图的自反传递闭包矩阵

        ④ 深度优先生成 

D_Search深度检索

         改造BFS算法,用栈来保存未被检测的结点,则得到的新的检索算法        

        注:结点被压入栈中后将以相反的次序出栈。 

回溯法

        用于求解问题的一组特定性质的解或满足某些约束条件的最优解。

        什么样的问题适合用回溯法求解呢?

        1)问题的解可用一个n元组(x1 ,…,xn )的向量来表示; 其中的xi取自于某个有穷集Si。

        2)问题的求解目标是求取一个使某一规范函数P(x1 ,…,xn ) 取极值或满足该规范函数条件的向量(也可能是满足P的所有向量)。

        约束条件:问题的解需要满足的条件,可以分为显式约束条件和隐式约束条件:

                显式约束条件:一般用来规定每个xi的取值范围。 如 : xi≥0 即Si={所有非负实数} xi=0或xi=1 即 Si={0,1}

                隐式约束条件:用来规定解空间中那些满足规范函数的元组, u 隐式约束条件描述了xi之间的关系和应满足的条件。

        解空间:实例I的满足显式约束条件的所有元组,构成的解空间,即所有xi合法取值的元组的集合——可行解。

        

        举例——8-皇后问题

                在一个8×8棋盘上放置8个皇后,使得任意两个皇后之间 都不互相“攻击” ,即每两个皇后都不在同一行、同一列或同 一条斜角线上。

        行、列号:1…8 皇后编号:1…8, 不失一般性,约定皇后i放到第i行的某一列上。

        解的表示:用8-元组(x1 ,…,x8 )表示 ,其中xi是皇后i所在的列号。

        显式约束条件:Si={1,2,3,4,5,6,7,8}, 1≤i≤8

        解空间:所有可能的8元组,共有8^8个。

        隐式约束条件:用来描述xi之间的关系,即没有两个xi可以相同,且没有两个皇后可以在同一条斜角线上。 由隐式约束条件可知:可能的解只能是( 1,2,3,4,5,6,7,8 )的 置换(排列),最多有8!个。

        举例——子集和数问题

        已知n个正数的集合W={w1 , w2 , …, wn}和正数M,找出W 中的和数等于M的所有子集。

        子集和数问题解的表示

        形式一

                问题的解为k-元组(x1 , x2 , …, xk), 1≤k≤n。不同的解可以是大小不同的元组,如(1,2,4)和(3,4)。

                显式约束条件:xi∈{ j | j为整数且1≤j≤n }。

                隐式约束条件:1)没有两个xi是相同的; 2)Wxi的和为M; 3)xi<xi+1 , 1≤ i<n(避免重复元组)

        形式二 

                解由n-元组(x1 , x2 , …, xn )表示,其中xi∈{0,1}。如果选择了 wi,则xi=1,否则xi=0。 

                特点:所有元组具有统一固定的大小。

                显式约束条件:xi∈{0,1} ,1≤i≤n;

                隐式约束条件:Σ(xi × wi) = M

解空间的组织

        回溯法将通过系统地检索给定问题的解空间来求解,从而需要有效地组织问题的解空间。

        可以用树结构组织解空间,形成状态空间树。

        如:4皇后问题的解空间树结构如图

        状态空间树:解空间的树结构称为状态空间树。

        问题状态:树中的每一个结点代表问题的一个状态,称为问题状态。

        状态空间:由根结点到其他结点的所有路径确定了这个问题的状态空间。

         解状态:是这样一些问题状态S,对于这些问题状态,由根到S的那条路径确定了这个问题解空间中的一个元组。

        答案状态:是这样的一些解状态S,对于这些解状态而言,由根到 S的这条路径确定了问题的一个解(满足隐式约束条件 的解)。

        状态空间树的构造

        以问题的初始状态作为根结点,然后系统地生成其它问题状态的结点。

        在状态空间树生成的过程中,结点根据被检测情况分为三 类:

  •         活结点:自己已经生成,但其儿子结点还没有全部生成并且 有待生成的结点。(静态)
  •         E-结点(expansion node):当前正在生成其儿子结点的 活结点。(动态)
  •         死结点:不需要再进一步扩展或者其儿子结点已全部生成的结点。

        构造状态空间树的两种策略

        1. 深度优先策略:当E-结点R一旦生成一个新的儿子C时, C就变成一个新的E-结点,当完全检测了子树C之后,R结点再次成为E-结点。

        2. 宽度优先策略:一个E-结点一直保持到变成死结点为止。

        限界函数

        在结点生成的过程中,定义一个限界函数,用来杀死还没有生成全部儿子结点的一些活结点 ——这些活结点已无法满足限界函数的条件, 因此不可能导致问题的答案。

        回溯法:使用限界函数的深度优先状态结点生成方法称为回溯法(backtracking)

        分支-限界方法:使用限界函数的 E 结点一直保持到死为止的状态结点生成方法称为分支-限界方法 (branch-and-bound)。

        4皇后问题的回溯法求解

  •         限界函数:如果(x1 ,x2 ,…,xi-1)是到当前E结点的路径, 那么xi-1的儿子结点xi是一些这样的结点, 它们使得(x1 ,x2 ,…,xi-1 ,xi)表示没有两个皇 后处在相互攻击状态的一种棋盘格局。
  •         开始状态:根结点1,此时表示棋盘为空,还没有放置 任何皇后。
  •         结点的生成:依次考察皇后1——皇后n的位置。

                

回溯法框架 

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1355825.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

VSCode远程连接centos

1 下载remote -ssh插件 2 在上方打开命令面板,输入>,再输入ssh,选择设置 Remote-SSH:Settings 那行 3 勾选下面这个选项 4 点击加号旁边的那个齿轮,选择.ssh\config ,配置连接信息,保存好后,刷新。 4 连接centos,然…

springBoot2.3-简单了解依赖管理、自动配置

一、自动依赖管理 基本介绍:springBoot提前帮我们写好了极多的依赖及版本号,当然我们也可以自定义依赖项与版本号。 1.1 简单介绍 1、在入门案例中,springBoot的maven中引入了parent父工程 2、ctrl 左键 parent, 发现里边还有…

图像融合算法

图像融合是将两个或多个图像或图像的特定部分合并在一起的过程。这可以通过各种图像融合算法来实现,这些算法可以用于不同的应用,如图像编辑、计算机视觉和医学图像处理。以下是一些常见的图像融合算法: 透明度融合(Alpha Blendi…

智能洗地机哪款最好用?智能洗地机推荐

洗地机是一种非常实用的家居清洁设备,可以有效地清理地面上的污垢和灰尘,给人们的生活带来了极大的便利性。那么洗地机哪个牌子最好用呢?市场上出现了越来越多的洗地机品牌,究竟哪一款智能洗地机更好用呢?本文将为大家简单介绍一下! 在选择…

这份江苏“最牛”医院和科室名单,我们核实过了

这份榜单不仅评出了全国100家最具科技影响力医院 还公布了25个医院学科影响力排行 那么,江苏哪些医院和科室入榜了呢? ▲戳大图更清晰 具体到学科排名 是这样的 心血管病 ▲戳大图更清晰 呼吸病学 ▲戳大图更清晰 消化病学 ▲戳大图更清晰 血液病…

接口和抽象类有什么共同点和区别?

共同点: 都不能被实例化。都可以包含抽象方法。都可以有默认实现的方法(Java 8 可以用 default 关键字在接口中定义默认方法)。 区别: 接口主要用于对类的行为进行约束,你实现了某个接口就具有了对应的行为。抽象类…

halcon 缺陷检测--形状匹配+差分

一、前言 本篇主要总结使用halcon 做缺陷检测的一个常用思路,当一张图片拍摄多个待检测工件,常用方法是由预先建立好的模版图像,采用 形状匹配查分方法抠下每个工件,逐个检测。 形状匹配比灰度值匹配要更为可靠 二、代码 代码是对…

目标管理(案例)

介绍 本篇Codelab将介绍如何使用State、Prop、Link、Watch、Provide、Consume管理页面级变量的状态,实现对页面数据的增加、删除、修改。要求完成以下功能: 实现一个自定义弹窗,完成添加子目标的功能。实现一个可编辑列表,可点击指…

JUC AQS(AbstractQueuedSynchronizer)

文章目录 AQS (AbstractQueuedSynchronizer^1.5^)CLH 锁队列AbstractQueuedSynchronizer 成员变量说明AbstractQueuedSynchronizer.Node 源码CLH 队列原理图入队逻辑方法出队逻辑方法 继承 AQS 需要实现的几个方法AQS 对象序列化ReentrantLock 源码解析R…

Day7 vitest 之 vitest配置第三版

项目目录 runner Type: VitestRunnerConstructor Default: node, 当运行test的时候 benchmark,当运行bench测试的时候 功能 自定义测试运行程序的路径。 要求 应与自定义库运行程序一起使用。 如果您只是运行测试,则可能不需要这个。它主要由library作者使用 …

kubernetes(K8s)的使用和常用命令

K8S kubernetes,由于k和s之间有8个字符,所以简称k8s,是一个全新的基于容器技术的分布式架构领先方案,是谷歌严格保密十几年的秘密武器----Borg系统的一个开源版本,于2015年7月发布第一个正式版本,它的本质…

HTML如何设置多图片上传,并限制格式类型

在HTML如何设置多图片上传&#xff0c;并限制格式类型为jpg和png格式。 <input type"file" name"fileInput" id"fileInput"> 上面这行代码&#xff0c;只支持单个文件上传&#xff0c;且不支持文件类型过滤&#xff0c;在实际开发过程中&…

HTML5+CSS3+Vue小实例:彩色圆环溶解加载动画

实例:彩色圆环溶解加载动画 技术栈:HTML+CSS+Vue.js 效果: 源码: 【HTML】 <!DOCTYPE html> <html lang="zh-CN"> <head><meta charset="UTF-8"><meta http-equiv="X-UA-Compatible" content="IE=edge&…

「HarmonyOS」验证码多TextInput输入框焦点自动跳转问题

需求背景&#xff1a;需要做一个多输入框的验证码模块&#xff0c;输入验证码时输入后光标会自动跳转至下一个输入框&#xff0c;删除验证码时会自动删除上一个输入框内容&#xff0c;并且光标跳转至上一个输入框内。6位验证码全部输完后进行登录请求 具体样式如下图&#xff1…

RFID数据中心智能资产管理系统

数据中心机房承担着保障企业关键数据处理的重要责任&#xff0c;机房的日常管理直接关系到整体机房的日常维护和运行安全&#xff0c;数据资产管理中心在监管机房各部分设备的运行情况、维护数据中心的资产方面发挥着重要的作用。 成功的数据中心机房管理不仅需要选择高可靠性…

理解UML中的依赖关系

理解UML中的依赖关系 在面向对象的设计中&#xff0c;理解各种类之间的关系对于构建一个清晰、可维护的系统至关重要。UML&#xff08;统一建模语言&#xff09;为我们提供了一种可视化这些关系的方式。今天&#xff0c;我们将深入探讨UML中的依赖关系&#xff08;Dependency&a…

Kubernetes 核心实战之一(精华篇 1/2)

文章目录 1&#xff0c;资源创建方式1.1 yaml1.2 命令行 2&#xff0c;NameSpace命名空间2.1 命令行创建ns2.2 yaml 创建ns 3&#xff0c;Pod3.1 命令行 创建pod3.2 yaml 创建pod3.3 可视化界面 创建3.3.1 Pod nginx3.3.2 Pod nginx tomcat3.3.3 Pod 2ngnix 1&#xff0c;资源…

ThreadLocal线程重用导致用户信息错乱的 Bug

在生产上遇到一个诡异的问题&#xff0c;有时获取到的用户信息是别人的。查看代码后&#xff0c;我发现他使用了 ThreadLocal 来缓存获取到的用户信息。 我们知道&#xff0c;ThreadLocal 适用于变量在线程间隔离&#xff0c;而在方法或类间共享的场景。如果用户信息的获取比较…

软件测试第二部分:白盒测试

概念与定义 白盒测试&#xff1a;侧重于系统或部件内部机制的测试&#xff0c;类型分为分支测试&#xff08;判定节点测试&#xff09;、路径测试、语句测试。 控制流分析(基于程序结构)&#xff1a;控制流分析是一类用于分析程序控制流结构的静态分析技术&#xff0c;目的在于…

8个流行的Python可视化工具包,你喜欢哪个?

用 Python 创建图形的方法有很多&#xff0c;但是哪种方法是最好的呢&#xff1f;当我们做可视化之前&#xff0c;要先明确一些关于图像目标的问题&#xff1a;你是想初步了解数据的分布情况&#xff1f;想展示时给人们留下深刻印象&#xff1f;也许你想给某人展示一个内在的形…