一道算法期末应用题及解答

1.印刷电路板布线区划分成为n m 个方格,确定连接方格a 到方格b 的最短布线方案。

在布线时,只能沿直线或者直角布线,为避免交叉,已经布线的方格做了封锁标记,其他线路不允许穿过被封锁的方格,某待布线电路板如下图所示,灰色方格为已封锁位置:

(1)描述求解该问题的算法策略和解题步骤;

(2)针对方格中数据,求得从方格a 到方格b 的最短布线方案,并说明求解的全过程。

解答:

(1)、每个结点最多有4 个扩展方向,搜索的方向比较盲目,因此求最短布线比较适合采用FIFO 分枝搜索策略。

步骤:

  1. 开始时,唯一的活结点是a,进入活结点队;
  2. 从活结点队中取出队头成为E- 结点;
    3、对E- 结点寻找可行位置入队;
    4、重复该过程直到b 结点或者队为空;
    5、如果b 结点终止则倒推输出路径,否则输出失败

(2)、活结点的扩展轮次如下图中编号所示:

布线路径如图中箭头所示。

相关推荐
时光追逐者2 分钟前
C# 哈希查找算法实操
算法·c#·哈希算法
上官浩仁3 分钟前
springboot synchronized 本地锁入门与实战
java·spring boot·spring
Gogo8164 分钟前
java与node.js对比
java·node.js
SmartJavaAI10 分钟前
Java调用Whisper和Vosk语音识别(ASR)模型,实现高效实时语音识别(附源码)
java·人工智能·whisper·语音识别
用户37215742613514 分钟前
Python 高效实现 Word 转 PDF:告别 Office 依赖
java
渣哥19 分钟前
Java ThreadPoolExecutor 动态调整核心线程数:方法与注意事项
java
Jasmine_llq26 分钟前
《P3825 [NOI2017] 游戏》
算法·游戏·枚举法·2-sat 算法·tarjan 算法·邻接表存储
Miraitowa_cheems30 分钟前
LeetCode算法日记 - Day 38: 二叉树的锯齿形层序遍历、二叉树最大宽度
java·linux·运维·算法·leetcode·链表·职场和发展
wangzy198230 分钟前
图形基础算法:如何将点与带曲线边的多边形位置关系算法做稳定
算法
wanzhong233335 分钟前
学习triton-第1课 向量加法
开发语言·python·高性能计算