3.8 电路布线

news2025/1/16 3:54:22

 


  •  博主简介:一个爱打游戏的计算机专业学生
  • 博主主页: @夏驰和徐策
  • 所属专栏:算法设计与分析

 1.最优子结构的证明:

我的理解:

对于电路布线问题的最优子结构性质,我们可以通过数学推导进行证明。下面是对证明的逐步解释:

假设对于前i条连线,我们已经找到了一个最大不相交连线子集MNS(i, D),其中D表示第i条连线连接的接线柱。

我们要证明的是,当我们考虑第i+1条连线时,能够得到一个最大不相交连线子集MNS(i+1, D'),其中D'表示第i+1条连线连接的接线柱。

根据电路布线问题的定义,第i+1条连线和任何其他连线相交的充分必要条件是D和D'都是0。

我们可以进行如下的推导:

1. 当i = 0时,即只有一条连线时,MNS(0, D) = K,其中K表示满足条件D ≤ T(1)的连线的数量。这是基本情况。

2. 当i > 0时,我们可以考虑第i+1条连线是否连接到接线柱D'上:
   a. 若第i+1条连线不连接到接线柱D'上,那么MNS(i+1, D') = MNS(i, D'),即前i条连线在接线柱D'上的最大不相交连线子集。
   b. 若第i+1条连线连接到接线柱D'上,那么我们需要找到不与第i+1条连线相交的最大不相交连线子集。
      这个子集可以表示为MNS(i, T(i+1)),即前i条连线在接线柱T(i+1)上的最大不相交连线子集。
      因此,MNS(i+1, D') = 1 + MNS(i, T(i+1))。

综上所述,我们得到了递归的最优子结构关系,即MNS(i+1, D')的最优解可以通过MNS(i, D')和MNS(i, T(i+1))的最优解来获得。

通过这种递归的方式,我们可以构建一个动态规划算法来解决电路布线问题,其中每个子问题的最优解可以由更小规模的子问题的最优解推导出来,最终得到整体问题的最优解。这证明了电路布线问题具有最优子结构性质。

2.递归计算最优值

为了推导出电路布线问题在动态规划下的递归计算最优值,我们可以定义一个状态转移方程来表示最优解的递归关系。

设MNS(i, D)表示前i条连线在接线柱D上的最大不相交连线子集的大小。

我们可以考虑第i条连线连接到接线柱D上和不连接到接线柱D上两种情况:

1. 如果第i条连线不连接到接线柱D上,那么MNS(i, D)等于前i-1条连线在接线柱D上的最大不相交连线子集的大小,即MNS(i-1, D)。

2. 如果第i条连线连接到接线柱D上,那么我们需要找到不与第i条连线相交的最大不相交连线子集。这个子集可以表示为前i-1条连线在接线柱T(i)上的最大不相交连线子集的大小加上1,即MNS(i-1, T(i)) + 1。

因此,我们可以得到状态转移方程:

MNS(i, D) = max{MNS(i-1, D), MNS(i-1, T(i)) + 1}

其中,max表示取两者中的较大值。

通过这个状态转移方程,我们可以从较小规模的子问题开始,逐步计算出更大规模的子问题的最优解。最终,我们可以得到整体问题的最优解MNS(n, D),其中n表示总连线数,D表示第n条连线连接的接线柱。

这样,我们就推导出了电路布线问题在动态规划下的递归计算最优值的方法。

 

3.构造最优解

要构造电路布线问题的最优解,可以使用回溯法来追踪最优解的路径。回溯法通过从最优解的最后一个状态开始,逐步回溯到初始状态,记录每个状态的选择,从而构造出最优解的具体方案。

以下是一个简单的算法框架:

1. 定义一个数组或列表best_solution,用于存储最优解的连线方案。

2. 从最后一个状态开始,即MNS(n, D),其中n表示总连线数,D表示第n条连线连接的接线柱。

3. 根据状态转移方程MNS(i, D) = max{MNS(i-1, D), MNS(i-1, T(i)) + 1},选择使得MNS(i, D)最大的连线方案。

4. 如果选择了第i条连线不连接到接线柱D上,则继续回溯到MNS(i-1, D)。

5. 如果选择了第i条连线连接到接线柱D上,则将第i条连线加入到best_solution中,并继续回溯到MNS(i-1, T(i))。

6. 重复步骤3-5,直到回溯到初始状态MNS(0, 0)。

7. 此时,best_solution中存储的就是构造出的最优解,其中连线的顺序即为回溯的顺序。

通过这个回溯过程,我们可以得到电路布线问题的最优解方案,即将哪些连线安排在第一层上,使得第一层上有尽可能多的连线。

4.计算复杂性

MNS算法需要O(n^2)计算时间和O(n^2)的空间。Traceback需要O(n)计算时间

总结:

电路布线问题是动态规划中的一个经典问题,其重点、难点和易错点如下:

重点:
1. 定义状态:在电路布线问题中,需要定义状态来表示问题的子结构和最优解的特征。
2. 状态转移方程:需要找到递推关系,将问题划分为更小的子问题,并通过状态转移方程来计算子问题的最优解。
3. 最优子结构性质:需要证明电路布线问题满足最优子结构,即全局最优解可以通过局部最优解得到。

难点:
1. 状态的设计:选择合适的状态来表示问题的子结构,使得状态转移方程能够描述问题的特征和关系。
2. 状态转移方程的推导:推导出准确且有效的状态转移方程,需要对问题进行深入分析和思考。
3. 问题规模的控制:电路布线问题的规模较大,需要设计合适的算法和数据结构来处理大规模的问题。

易错点:
1. 数组越界:在动态规划的过程中,需要注意数组的索引范围,避免越界访问。
2. 边界条件处理:对于边界情况,如初始状态和递归的终止条件,需要仔细处理,确保算法的正确性。
3. 状态转移方程的实现:在实现状态转移方程时,需要注意计算顺序和辅助变量的更新,确保结果的准确性。

综上所述,电路布线问题在动态规划中具有一定的复杂性,需要仔细分析问题特点,设计合适的状态和状态转移方程,同时注意处理边界情况和避免常见的易错点,才能得到正确的解答。

 

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

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

相关文章

conda在 powershell下不能激活虚拟环境

这里写自定义目录标题 问题原因解决办法增加环境变量修改PowerShell 策略初始化conda环境安装或更新conda 结果 问题原因 powershell正常是不行的,但是在cmd中是可以的 问题产生的原因有很多: 必须无法识别activate.bat激活无反应 解决办法 增加环…

【JavaSE】Java基础语法(四十六):枚举

文章目录 1. 概述2. 定义格式3. 枚举的特点4. 枚举的方法 1. 概述 枚举是一种特殊的数据类型,它列出了一组预定义的常量,并使用标识符来引用这些常量。枚举的用途很广泛,下面列举了几个常见的应用场景: 管理常量:如果您…

计算机组成原理---第三章存储系统 习题详解版

(一)精选课内习题 3.1 3.2 3.3 3.4 3.5 3.6 3.7 3.8 (二)精选课后习题 1.设有一个具有20位地址和32位字长的存储器,问: (1)该存储器能存储多少个字节的信息? (2)如果存储器由512k8位的SR…

Linux :: vim 编辑器:详解:文本复制/粘贴/剪切/删除 与 撤销普通操作及撤销撤销操作

前言:本篇是 Linux 基本操作篇章的内容! 笔者使用的环境是基于腾讯云服务器:CentOS 7.6 64bit。 学习集: C 入门到入土!!!学习合集Linux 从命令到网络再到内核!学习合集 前文&#x…

chatgpt赋能python:Python去掉None:提高代码效率,优化SEO

Python去掉None:提高代码效率,优化SEO 作为一名有10年Python编程经验的工程师,我发现Python中会频繁出现None类型的变量。这种情况在代码中一旦过多,就会影响程序的效率,同样也会影响SEO的排名。因此,为提…

【数据仓库架构】什么是 Azure Synapse,它与 Azure Data Bricks 有何不同?

Azure Synapse Analytics 是一项针对大型公司的无限信息分析服务,它被呈现为 Azure SQL 数据仓库 (SQL DW) 的演变,将业务数据存储和宏或大数据分析结合在一起。 在处理、管理和提供数据以满足即时商业智能和数据预测需求时,Synapse 为所有工…

Hive学习---5、文件格式和压缩、企业级调优

1、文件格式和压缩 1.1 Hadoop压缩概述 由于Hive是相当于与Hadoop的客户端,所以hadoop会啥压缩,Hive基本就会啥压缩。 压缩格式算法文件扩展名是否可切分DEFLATEDEFLATE.deflate否GzipDEFLATE.gz否bzip2bzip2.bz2是LZOLZO.lzo是SnappySnappy.snappy否…

word恢复和粘贴按钮变灰色,不可用怎么办?

如果 Word 中的恢复和粘贴按钮变成灰色,可能是由于以下原因之一: 1. 文档处于只读模式。 2. 与 Office 相关的某些组件已损坏或缺失。 3. Word 的文件权限被配置为只读。 以下是一些可能的解决方法: 1. 检查文档是否处于只读模式。 如果是…

随机数发生器设计(三)

随机数发生器设计(三)- 熵估计和健康测试 熵估计健康测试 熵估计 考虑都熵源的多样性,建立一个通用的熵估计模型比较困难。本文采用nist.sp.800-90B推荐的Markov评估。详见 https://doi.org/10.6028/NIST.SP.800-90B。 执行Markov评估时&am…

chatgpt赋能python:用Python向手机发送信息是如何实现的?

用Python向手机发送信息是如何实现的? 在今天的信息时代,随时随地保持联系已经成为生活不可或缺的一部分。随着技术的发展,我们可以使用各种方式发送和接收信息,而使用Python向手机发送短信是其中一种非常方便的方式。 Python的…

I.MX6ull EPIT定时器

一 简介 EPIT定时器是一种增强的周期中断定时器,完成周期性中断定时的功能。 具有以下特点 EPIT定时器是一个32位的定时器 时钟源可选的向下计数器 EPIT 共有 3 个时钟源可选择,ipg_clk、ipg_clk_32k 和 ipg_clk_highfreq 当计数值和比较值相等的时候…

兼顾性能+实时性处理缓冲数据解决方案

我们经常会遇到这样的数据处理应用场景:我们利用一个组件实时收集外部交付给它的数据,并由它转发给一个外部处理程序进行处理。考虑到性能,它会将数据存储在本地缓冲区,等累积到指定的数量后打包发送;考虑到实时性&…

ChatGPT与软件架构(3) - 软件架构提示工程

高效利用ChatGPT辅助研发的关键是在研发生命周期的不同阶段采用对应提示获取有益的帮助。原文: Leveraging Prompt Engineering in Software Architecture with ChatGPT 软件架构开发生命周期转型。 Beth Smith Unsplash 简介 作为解决方案架构师,有必要掌握软件架构…

【分布式架构】资源与事务:可观测性的基本二重性

西格曼:我叫本西格曼。我是Lightstep的联合创始人兼首席执行官。我在这里讨论的是资源和事务,这是可观察性的一个基本的二元性。我职业生涯的大部分时间都在研究可观察性。在我职业生涯之初,我在谷歌工作了九年,致力于谷歌的分布式…

SLAM实战项目(1) — ORB-SLAM2稠密地图重建

目录 1 整体思路 2 功能实现 3 结果运行 (1) TUM数据集下载 (2) associate.py用于RGB和Depth匹配 (3) 运行数据集 4 CMakeLists.txt文件修改 5 完整PointCloudMapping.h和PointCloudMapping.cc 6 报错分析 7 思考扩展 文章参考部分开源代码和报错文章 1 整体思路 利…

【微信小程序开发】第 3 节 - 安装开发者工具

欢迎来到博主 Apeiron 的博客,祝您旅程愉快 ! 时止则止,时行则行。动静不失其时,其道光明。 目录 1、缘起 2、微信开发者工具 3、下载 4、安装 5、扫码登录 6、设置外观和代理 7、总结 1、缘起 开发微信小程序从大的方…

吊打面试官的16000字JVM专属秘籍,又一个Java面试神器!终于可在简历写上精通JVM了!

前言 吊打面试官的16000字JVM专属秘籍,总共包含三部分的内容,从基础到进阶带大家一步步深入理解JVM! 学完就可以在简历上面直接写上精通JVM! 因为篇幅限制这里只给大家做简单的一个介绍,也就是进行一个大点的梳理&a…

记录--手把手教你Vue+ECharts+高德地图API实现天气预报数据可视化

这里给大家分享我在网上总结出来的一些知识,希望对大家有所帮助 前言 所谓数据可视化,我们可以理解为从宏观角度来看一眼就能看出来整个数据的占比,走向。对于数据可视化,很多互联网公司是很看重这一块的,包括大厂&…

基于wireshark打造安全分析师工具--解析suricata中的分析结果

从本篇文章开始,我将通过若干篇文章陆续介绍在实际安全运营的过程中,基于wireshark打造安全分析师趁手的流量威胁分析工具,帮助安全分析人员在面对网络数据包取证和分析时候达到事半功倍的效果。本篇文件介绍使用在使用iwreshark分析数据包事…

21天学会C++:Day7----auto关键字

CSDN的uu们,大家好。这里是C入门的第七讲。 座右铭:前路坎坷,披荆斩棘,扶摇直上。 博客主页: 姬如祎 收录专栏:C专题 目录 1. 知识引入 2. auto的使用 2.1 auto与指针和引用结合起来使用 2.2 在同一…