算法导论实战(六)(算法导论习题三十四、三十五章)

🌈 个人主页:十二月的猫-CSDN博客
🔥 系列专栏: 🏀算法启示录

💪🏻 十二月的寒冬阻挡不了春天的脚步,十二点的黑夜遮蔽不住黎明的曙光 

前言

算法导论的知识点学习将持续性更新在算法启示录_十二月的猫的博客-CSDN博客,欢迎大家订阅呀(反正是免费的哦~~)

实战篇也将在专栏上持续更新,主要目的是强化对理论的学习(题目来源:山东大学孔凡玉老师推荐)

目录

前言

第三十四章

34.1-4

34.5-1

34.5-5

第三十五章

35.1-4

35.2-3

总结


第三十四章

34.1-4

问题描述:

练习 16. 2-2 中曾要求读者给出的 0-1 背包问题的“动态规划算法“,它是一个多项式时间的算法吗?解释你的答案。

问题分析:

首先回忆:0-1背包问题的动态规划算法是什么?

0-1背包动态规划算法:

0-1bag(w,v,n,m) //n表示物品数量,m表示背包最大重量let d(i,j) be a Two-dimensional arraysfor i=0 to nd(i,0)=0for j=1 to md(0,j)=0for i =1 to nfor j=1 to mif(j>w(i))d(i,j)=max(d(i-1,j),d(i-1,j-w(i))+v(i))elsed(i,j)=d(i-1,j)

分析算法我们不难知道算法的时间复杂度为O(nm),其中n为物品最大数量,m为背包重量上限 


问题本质就是让我们思考O(nm)这个时间复杂度是不是多项式时间的

时间复杂度分为:编码时间复杂度、非编码时间复杂度

很多算法在非编码情况下时间复杂度为多项式时间的,但是在编码下就是非多项式时间 

编码时间复杂度更贴和计算机实际运行的情况 

问题求解:

这不是一个多项式时间的算法。考虑问题的编码。通过给出每个物品的索引、价值和重量的二进制表示,可以进行多项式编码,这些被表示为长度为a = Ω(n)的二进制字符串(每个物品独立需要一串编码,不能用两个位表示四个物品)。我们在多项式时间内对W进行编码,这将有长度为Θ(log W) 的编码(能用两位表示四个重量)。这个长度为a + b的问题的解的时间为Θ(nW) = Θ(a · 2^b)。因此,该算法实际上是指数级的。

注:本题实际上是问算法实际运行的时间复杂度

34.5-1

问题描述:

子图同构问题取两个无向图 G1、G2, 要回答 G1 是否与 G2 的一个子图同构这一问题。 证明:子图同构问题是 NP 完全的。(本题就是证明子图同构问题是NP完全问题

问题分析:

证明L问题是NP完全问题的步骤:

  1. 证明L∈NP
  2. 选取一个已知的NP完全问题L’
  3. 描述一个归约函数f(x)能够把L‘归约到L
  4. 证明归约函数f的归约是多项式时间的
  5. 当且仅当L‘有解时L有解

总的思路:假设L’有解将每个实例归约成L,此时L也有解;但是L‘是NPC问题,所以L也是NPC问题无解

问题求解:

1、假如我们得到了G1、G2以及其对应的解——G2的子图G2‘与G1同构。此时我们只需要遍历G2’中的点和每一个与点相连的边,同时检查G1中是够有对应的点即可验证。这个验证的时间复杂度是O(EV)(其中E为G2‘的边集,V为G1的点集),所以是多项式时间。但是假如不知道G2哪个子图与G1同构,要去寻找的话,由于G2的子图有2^n个,所以寻找的时间显然不是多项式时间

2、选择团问题作为已知的NPC问题,接下去思考如何把团问题归约到子图同构问题上

3、假如现在我们有一个有解团问题<G,k>,即G中存在一个k规模的团(即有k个点的完全子图),记这个完全子图为Gk。此时我们构造一个G2,令G2是和Gk一样规模的完全子图。那么我们将G和G2放到子图同构中不难证明,G一定有子图Gk与G2同构

4、假如G有子图Gk与G2同构,那么至少G中会存在规模为k的团,即L语言在NPC问题L’中一定有对应的解。同时团问题有解时由3可知子图同构问题也一定有解。所以当且仅当关系证明完毕!

5、由于归约算法中,我们仅仅构造一个规模为k的完全图G2,所以这个归约算法是多项式时间内可以完成的

34.5-5

问题描述:

给定一个整数集合S,求集合S的一个划分S1和S2(即:S=S1∪S2且S1∩S2=Φ),使得S1中的元素之和等于S2中的元素之和(本题就是证明集合划分问题是NPC问题)

问题分析:

证明L问题是NP完全问题的步骤:

  1. 证明L∈NP
  2. 选取一个已知的NP完全问题L’
  3. 描述一个归约函数f(x)能够把L‘归约到L
  4. 证明归约函数f的归约是多项式时间的
  5. 当且仅当L‘有解时L有解

总的思路:假设L’有解将每个实例归约成L,此时L也有解;但是L‘是NPC问题,所以L也是NPC问题无解

问题求解:

1、假如给定一个集合S的划分S1和S2,那么分别对S1和S2的元素求和并比较,因此可以在多项式时间验证这个集合划分的正确性。同时如果并没有给这个S的划分,那么S1和S2的划分个数都有2^n个,所以寻找S1、S2算法的时间复杂度肯定不是多项式时间的

2、选择子集和求和问题作为已知NPC问题

3、假如存在一个集合U,已知其中的元素xi、xj,....,等之和为t,t为提前已经设定好的量。那么我们取这个集合U,令U’=U 并 {U-2t},此时U‘中就存在几个可拆分的集合对象。这时,可以确定新集合U‘中的集合元素可以拆分为两个U-t。因为只要将集合{U-2t}中的t挪动到U中即可。而t已知为xi、xj,....,等元素的和,所以是可以挪动的。证毕!

4、归约算法仅仅涉及有限集合的并以及拆操作,所以整体的归约时间必然是多项式的

5、当新集合U'中元素可以拆分为两个相等的元素时,我们可以令这两个相等元素为U-t。那么重新拆分组合这两个元素,可以得到集合U,并且其中有元素求和为t。也就是说此时集合U的子集和问题必然存在解。

第三十五章

35.1-4

问题描述:

给出一个有效的贪心算法,使其能够在线性时间内找出一棵树的最优顶点覆盖。

问题分析:

已知顶点覆盖算法是NPC难度的,题目要我们找可行的线性时间算法,本质就是让我们去使用近似算法找最优顶点覆盖

 所谓贪心算法实现就是算法导论中的方法

问题求解:

APPROX-VERTEX-COVER(G)C=ØE'=G.Ewhile(E'!=Ø)let (u,v) be a arbitrary edge of E'C=C ∪ (u,v)remove from E' every edge incident on either u or vreturn C

 该算法是一个多项式时间的2近似算法

问题深究: 

下面给出证明,说明为什么这个算法是多项式时间的2近似算法

 证:

定义C:为算法实际找出的顶点覆盖;C*:为图G最优顶点覆盖;A为算法找出的边的集合

由于每找到一个边(u,v)则把与u或v连接的边删除,所以A集合中没有两个边存在共同的顶点,即所有边都是不相连的。因此,想要覆盖这些边至少需要边个数的顶点,即有:

\left | C^* \right |>=\left | A \right |

由由于A的边并不相交,所以并不存在一个点连接两个边的情况,每个边的两个端点都是不相同的。因此有:

\left | C \right |=2\left | A \right | 

结合上面两个式子,我们可以得到:

 \left | C \right |=2\left | A \right |<=2\left | C^* \right |

即该算法是多项式时间上的2近似算法 

35.2-3

问题描述:

考虑下述用于构造近似旅行商旅行路线(代价函数满足三角不等式)的最近点启发式:从只包含任意选择的某一顶点的平凡回路开始,在每一步中,找出一个顶点 u, 它不在回路中,但到回路上任何顶点之间的距离最短。假设回路上距离u最近的顶点为 v, 则将u插入到v之后,从而对回路加以扩展。重复这一过程,直到所有顶点都在回路上为止。 证明:这一启发式方法返回的旅行路线总代价不超过最优旅行路线代价的2倍。

 问题分析:

 证明近似算法与最优算法代价的近似比:

1、确定近似算法产生的结果;

2、确定最优算法产生的结果;

3、找到两者中间的联系桥点

4、通过桥点来判断近似算法和最优算法的近似比

问题求解: 

按照这个思路来求解近似算法的近似比 :

1、确定近似算法产生的结果:每次选择一个点,将点插入到原本的回路中间,从而完成回路的拓展

2、最优算法产生回路的方式:回忆通过最小生成树来确定旅行路线的方法,可以知道生成最优旅行路线我们是每次选择一个点然后将该点加入已知回路(注意是加入不是插入

3、 顶点覆盖近似算法每次找的是边,所以中点桥点就是|A|;旅行商问题的最小生成树近似算法依靠生成树来解决问题,所以中间桥点就是c(T),即生成树的权值和。本题不需要一个特定的桥点,因为近似结果和最优结果内部就存在桥点可以利用

4、假设回路中已经存在vi,vi+1,现在想要插入ui。利用近似算法每次插入一个点,新增的值:

c(u_i,v_i)+c(u_i,v_{i+1})-c(v_i,v_{i+1})

根据三角形理论可以知道下面不等式:

 c(u_i,v_{i+1})<=c(u_i,v_{i})+c(v_i,v_{i+1})

将第二个不等式代入第一个式子中有:

 c(u_i,v_i)+c(u_i,v_{i+1})-c(v_i,v_{i+1})<=2c(u_i,v_{i})

 而最优结果每次加入点新增的值为(因为已知ui到vi的距离是最短的):

c(u_i,v_i)

 因此可以证明,每次新增的值近似算法是最优算法新增值的两倍,所以从总的代价上看,近似算法最终耗费也是最优算法最终耗费的两倍。证毕!

总结

本文到这里就结束啦~~

本篇文章的撰写花了本喵三个多小时

如果仍有不够,希望大家多多包涵~~

如果觉得对你有帮助,辛苦友友点个赞哦~

知识来源:《算法导论》课后习题、山东大学孔凡玉老师ppt。不要用于商业用途转发~

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

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Docker 基础使用(2) 镜像与容器

文章目录 镜像的含义镜像的构成镜像的作用镜像的指令容器的含义容器的状态容器的指令 Docker 基础使用&#xff08;0&#xff09;基础认识 Docker 基础使用 (1) 使用流程概览 Docker 基础使用&#xff08;2&#xff09; 镜像与容器 Docker 基础使用&#xff08;3&#xff09; 存…

2024年【天津市安全员C证】免费试题及天津市安全员C证试题及解析

题库来源&#xff1a;安全生产模拟考试一点通公众号小程序 天津市安全员C证免费试题是安全生产模拟考试一点通生成的&#xff0c;天津市安全员C证证模拟考试题库是根据天津市安全员C证最新版教材汇编出天津市安全员C证仿真模拟考试。2024年【天津市安全员C证】免费试题及天津市…

VBA excel 表格将多行拆分成多个表格或 文件 或者合并 多个表格

excel 表格 拆分 合并 拆分工作表按行拆分为工作表工作表按行拆分为工作薄 合并操作步骤 拆分 为了将Excel中的数万行数据拆分成多个个每个固定行数的独立工作表&#xff0c;并且保留每个工作表的表头&#xff0c;你可以使用以下VBA脚本。这个脚本会复制表头到每个新的工作表&…

行心科技中禄松波携手,开启智能健康新时代

在2024年第34届健博会暨中国大健康产业文化节的盛大舞台上&#xff0c;广州市行心信息科技有限公司&#xff08;以下简称“行心科技”&#xff09;与浙江中禄松波生物工程有限公司&#xff08;以下简称“中禄松波”&#xff09;宣布达成战略合作&#xff0c;共同推动医康养产业…

socket通信(C语言+Python)

在socket文件夹下创建server.c和client.c。 服务端代码&#xff08;server.c&#xff09;&#xff1a; #include <stdio.h> #include <Winsock2.h> void main() {WORD wVersionRequested;WSADATA wsaData;int err;wVersionRequested MAKEWORD( 1, 1 );err WSAS…

探索 Noisee AI 的奇妙世界与变现之旅

日赚800&#xff0c;利用淘宝/闲鱼进行AI音乐售卖实操 如何让AI生成自己喜欢的歌曲-AI音乐创作的正确方式 抖音主播/电商人员有福了&#xff0c;利用Suno创作产品宣传&#xff0c;让产品动起来-小米Su7 用sunoAI写粤语歌的方法&#xff0c;博主已经亲自实践可行 五音不全也…

通道堵塞自动识别摄像机

通道堵塞自动识别摄像机是一种利用先进的人工智能和图像识别技术来监测和识别通道堵塞情况的装置&#xff0c;广泛应用于交通管制、商场管理等领域。这项技术的出现极大地提高了通道管理的效率和准确性&#xff0c;为改善人们的出行体验和商场营运提供了新的解决方案。 传统的通…

Vue3【十一】08使用toRefs和toRef

08使用toRefs和toRef toRefs()函数将person对象中的name和age属性转换为响应式引用&#xff0c;并返回一个对象&#xff0c;对象中的name和age属性都是响应式引用&#xff0c;具有响应式功能。 toRef()函数将person对象中的name属性转换为响应式引用&#xff0c;并返回一个响应…

Doris Connector 结合 Flink CDC 实现 MySQL 分库分表

1. 概述 在实际业务系统中为了解决单表数据量大带来的各种问题&#xff0c;我们通常采用分库分表的方式对库表进行拆分&#xff0c;以达到提高系统的吞吐量。 但是这样给后面数据分析带来了麻烦&#xff0c;这个时候我们通常试将业务数据库的分库分表同步到数据仓库时&#x…

最新PHP众筹网站源码 支持报名众筹+商品众筹+公益众筹等多种众筹模式 含完整代码包和部署教程

在当今互联网飞速发展的时代&#xff0c;众筹模式逐渐成为了创新项目、商品销售和公益活动融资的重要渠道。分享一款最新版的PHP众筹网站源码&#xff0c;支持报名众筹、商品众筹和公益众筹等多种众筹模式。该源码包含了完整的代码包和详细的部署教程&#xff0c;让新手也可以轻…

java之面向对象

1 面向对象介绍 <span style"background-color:#f8f8f8"><span style"color:#333333">1.面向过程:自己的事情自己干,代表语言C语言洗衣服:每一步自己要亲力亲为 -> 找个盆,放点水,找个搓衣板,搓搓搓 2.面向对象:自己的事情别人帮忙去干,代…

STM32 uc/OS-III多任务程序

目录 一、项目创建 二、代码移植 1、uC/OS-III源码处理 2、KEIL文件配置 ​编辑3、文件修改 启动文件 ​编辑app_cfg.h includes.h bsp.c和bsp.h main.c lib_ cfg.h app.c和app.h 三、总结 学习目标&#xff1a; 学习嵌入式实时操作系统&#xff08;RTOS&#xf…

三端植物大战僵尸杂交版来了

Hi&#xff0c;好久不见&#xff0c;最近植物大战僵尸杂交版蛮火的 那今天苏音整理给大家三端的植物大战僵尸杂交版包括【苹果端、电脑端、安卓端】 想要下载的直接划到最下方即可下载。 植物大战僵尸&#xff0c;作为一款古老的单机游戏&#xff0c;近期随着B站一位UP主潜艇…

【数据结构初阶】栈和队列

1. 栈 1.1 栈的概念及结构 栈&#xff1a;一种特殊的线性表&#xff0c;其只允许在固定的一端进行插入和删除元素操作。进行数据插入和删除操作的一端称为栈顶&#xff0c;另一端称为栈底。栈中的数据元素遵守后进先出LIFO&#xff08;Last In First Out&#xff09;&#xf…

HTML开发 Vue2.x + Element-UI 动态生成表单项并添加表单校验

基于vue2.x 和element-ui 动态生成表单项并添加表单校验&#xff1b; 1、需求问题 如下图&#xff0c;项目有个需求&#xff0c;点击添加按钮&#xff0c;新增一行设备信息&#xff0c;且每项信息必填&#xff1b; 2、代码 看到这个需求&#xff0c;首先想到要使用v-for的形…

springboot集成uid-generator生成分布式id

一、简介 uid-generator是由百度技术部开发,GitHub地址 UidGenerator是Java实现的, 基于Snowflake算法的唯一ID生成器 Snowflake算法 Snowflake算法描述&#xff1a;指定机器 & 同一时刻 & 某一并发序列&#xff0c;是唯一的。据此可生成一个64 bits的唯一ID&#x…

Windows 宿主机访问 VirtualBox 虚拟机中创建的 docker 容器中的 mysql8.0 的数据

一、场景需求 在开发环境中&#xff0c;一般使用 windows 系统进行开发&#xff0c;但需要在 linux 系统中创建运行 mysql8.0 的 docker 容器中进行测试&#xff08;win10特定版本或win11才能安装 docker&#xff09;&#xff0c;为了方便还需要在 windows 系统中通过 SQLyog …

Python轻量级嵌入式关系数据库之apsw使用详解

概要 在现代应用开发中,数据库是一个非常重要的组成部分。SQLite 是一个轻量级的嵌入式关系数据库管理系统,被广泛应用于各种应用程序中。APSW(Another Python SQLite Wrapper)库是一个专门用于访问 SQLite 数据库的 Python 包,它提供了 SQLite 所有的功能,并且比标准库…

【教学类-40-01】20240607类似MJ的免费AI绘画工具——文心一格与通义万相

背景需求&#xff1a; 风变的AI对话大师一年到期了&#xff0c;也没有看到续费的按钮。不能使用它写代码了。 MJ早就用完了&#xff0c;最后480次&#xff0c;我担心信息课题会用到它生图&#xff0c;所以不敢用。 最近探索其他类似MJ的免费出图工具 一、文心一格&#xff08;…

各种空气能热泵安装图

空气能热泵安装图 循环式空气能热泵安装图 直热循环式空气能热泵安装图 泳池空气能热泵安装图 循环式水源热泵热安装系统原理图 直热循环式水源热泵安装系统图 空气水源热泵安装图