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

🌈 个人主页:十二月的猫-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 arrays
    for i=0 to n
        d(i,0)=0
    for j=1 to m
        d(0,j)=0
    for i =1 to n
        for j=1 to m
            if(j>w(i))
                d(i,j)=max(d(i-1,j),d(i-1,j-w(i))+v(i))
            else
                d(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.E
    while(E'!=Ø)
        let (u,v) be a arbitrary edge of E'
        C=C ∪ (u,v)
        remove from E' every edge incident on either u or v
    return 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.mfbz.cn/a/693663.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

win设置ftp服务器~java通过ftp下载文件

1.先设置ftp 2.打开服务 3.设置站点 4.起名字 这样就可以了 5.剩下的就是设置权限和账号了&#xff0c;找到对应的按钮就可以了 6.下载文件的代码 public byte[] downloadFile(File file) throws IOException{ByteArrayOutputStream out new ByteArrayOutputStream();toDi…

把chatgpt当实习生,进行matlab gui程序编程

最近朋友有个项目需要整点matlab代码&#xff0c;无奈自己对matlab这种工科的软件完全是外行&#xff0c;无奈只有求助gpt这种AI助手了。大神们告诉我们&#xff0c;chatgpt等的助手已经是大学实习生水平啦&#xff0c;通过多轮指令交互就可以让他帮你完成工作啦&#xff01;所…

使用 Scapy 库编写 TCP RST 攻击脚本

一、介绍 TCP RST攻击是一种拒绝服务攻击&#xff08;Denial-of-Service, DoS&#xff09;类型&#xff0c;攻击者通过伪造TCP重置&#xff08;RST&#xff09;包&#xff0c;中断目标主机与其他主机之间的TCP连接。该攻击利用了TCP协议中的重置机制&#xff0c;强制关闭合法的…

倩女幽魂手游攻略:云手机自动搬砖辅助教程!

《倩女幽魂》手游自问世以来一直备受玩家喜爱&#xff0c;其精美画面和丰富的游戏内容让人沉迷其中。而如今&#xff0c;借助VMOS云手机&#xff0c;玩家可以更轻松地进行搬砖&#xff0c;提升游戏体验。 一、准备工作 下载VMOS云手机&#xff1a; 在PC端或移动端下载并安装VM…

C#操作MySQL从入门到精通(21)——删除数据

前言: 谈到数据库,大家最容易脱口而出的就是增删改查,本文就是来详细介绍如何删除数据。 本文测试使用的数据库如下: 1、删除部分数据 使用delete 关键字,并且搭配where条件使用,否则会导致表中数据全部被删除 string sql = string.Empty;if (radioButton_DeletePart…

基于Django+MySQL的智慧校园系统

此项目基于Django MySQL HTML CSS JS jQuery bootstrap实现的功能有 学生管理部门管理代办清单管理校园论坛校园医疗服务校园看点校园生活助手常用功能入口 1. 一些注意点 1. 页面body会自动有一些边界距&#xff0c;处理方法&#xff1a; <head><style>b…

(2024,自监督 ViT,全监督 ViT,损失可视化,MAE,RC-MAE,自蒸馏,EMA)可视化自监督 ViT 的损失景观

Visualizing the loss landscape of Self-supervised Vision Transformer 公和众和号&#xff1a;EDPJ&#xff08;进 Q 交流群&#xff1a;922230617 或加 VX&#xff1a;CV_EDPJ 进 V 交流群&#xff09; 目录 0 摘要 2 基础&#xff1a;MAE 和 RC-MAE 3 损失景观 3.1 分…

【Linux】进程5——进程优先级

1.进程优先级 1.1.什么是进程优先级 cpu资源分配的先后顺序&#xff0c;就是指进程的优先权&#xff08;priority&#xff09;。优先权高的进程有优先执行权利。配置进程优先权对多任务环境的linux很有用&#xff0c;可以改善系统性能。还可以把进程运行到指定的CPU上&#x…

爬虫可以不必自己写,使用ChatGPT编写抓取电影评论数据脚本

经常去新华书店看看有没有什么新书上架&#xff0c;还是更新挺及时的&#xff0c;可以反映新的技术趋势。这不&#xff0c;最近就看到了这本《巧用 ChatGPT 快速搞定数据分析》&#xff0c;作者是个大牛&#xff0c;第一次看到prompt可以这么写&#xff0c;得写这么长&#xff…

ipynb转markdown的简单方法

在线转换 推荐在线转换&#xff0c;拖进去后下载就行&#xff0c;简单易操作。 Convert Jupyter notebook to GitHub-Flavored Markdown for free on AlldocsThe free text converter for all your documents.https://alldocs.app/convert-jupyter-notebook-to-markdown vsc…

【C51】DIY电子音乐贺卡:C51单片机项目设计与实现

文章目录 前言&#xff1a;1. 要求&#xff1a;2. 实现效果&#xff1a;3. 准备工作&#xff1a;4. 编写代码&#xff1a;5. 导出bmp格式图片总结&#xff1a; 前言&#xff1a; 在当今数字化时代&#xff0c;电子贺卡以其独特的互动性和个性化特点&#xff0c;成为人们表达情…

Data Mining2 复习笔记6 - Optimization Hyperparameter Tuning

6. Optimization & Hyperparameter Tuning Why Hyperparameter Tuning? Many learning algorithms for classification, regression, … Many of those have hyperparameters: k and distance function for k nearest neighbors, splitting and pruning options in decis…

软件游戏d3dcompiler_47.dll缺失怎么办,多种有效的解决方法分享

在计算机使用过程中&#xff0c;我们可能会遇到各种软件错误提示&#xff0c;其中之一就是“d3dcompiler47.dll缺失”。这个错误提示可能会影响到我们的正常使用&#xff0c;甚至导致某些软件无法运行。那么&#xff0c;d3dcompiler47.dll缺失究竟会造成哪些问题呢&#xff1f;…

看似不同的事情,却是相同的坑

目录 一、背景二、过程1.遭遇战-微盘股的下杀2.不失为一件好事3.一切向后看吧&#xff0c;最近的学习感受4.该有的心境 三、总结 一、背景 也在一点点改变&#xff0c;期间势必要经历流血的过程&#xff1b;所谓无疯狂不成长&#xff0c;积极的心态去应对&#xff0c;去总结总…

R语言数据探索和分析22-使用随机森林和聚类算法探索和预测健康状况

一、研究背景 在两个实验中&#xff0c;使用了一组综合性的生物统计数据来探索和预测健康状况&#xff08;特别是疾病的发生&#xff09;。实验的核心在于应用高级数据分析技术&#xff0c;具体包括随机森林分类和聚类分析&#xff0c;来洞察和预测个体的健康状况。首先&#…

专业学习|南开大学《随机过程》学习笔记(一)

&#xff08;1&#xff09;有哪些经典的关于基本随机过程的书籍推荐&#xff1f; 对于想要系统学习基本随机过程的学生来说&#xff0c;可以参考Sheldon M.Rose编著的经典著作《随机过程》。该书涉及的内容也比较宽泛。但并不局限于单个细节论证。 此外&#xff0c;萨缪尔科林(…

SpringAOP 常见应用场景

文章目录 SpringAOP1 概念2 常见应用场景3 AOP的几种通知类型分别有什么常见的应用场景4 AOP实现 性能监控4.1 首先&#xff0c;定义一个切面类&#xff0c;用于实现性能监控逻辑&#xff1a;4.2 定义自定义注解4.3 注解修饰监控的方法 5 AOP实现 API调用统计5.1 定义切面类&am…

连续状态方程的离散化例子

连续状态方程的离散化 在控制系统中,连续状态方程的离散化是一个重要的步骤,用于将连续时间系统转换为离散时间系统,以便在数字控制器中实现。这通常涉及将连续时间的微分方程转换为离散时间的差分方程。常用的离散化方法 前向欧拉法(Forward Euler)简单易实现,但精度较…

在Anaconda中安装keras-contrib库

文章目录 1. 有git2. 无git2.1 步骤12.2 步骤22.3 步骤3 1. 有git 如果环境里有git&#xff0c;直接运行以下命令&#xff1a; pip install githttps://www.github.com/farizrahman4u/keras-contrib.git2. 无git 2.1 步骤1 打开网址&#xff1a;https://github.com/keras-tea…

刷代码随想录有感(97):动态规划——斐波那契数列

题干&#xff1a; 代码&#xff1a; class Solution { public:int fib(int n) {if(n < 1)return n;vector<int> dp(n 1);dp[0] 0;dp[1] 1;for(int i 2; i < n; i){dp[i] dp[i - 1] dp[i - 2];}return dp[n];} }; 动态规划五部曲&#xff1a; 1.dp数组的定…