求助:回溯法 装载问题

proof1 2017-02-20 04:44:43
回溯法解装载问题(轮船、集装箱,题略)。

可以引入一个上界函数,用于剪去不含最优解的子树,
设z是解空间树第i层上的当前扩展结点。cw是当前载重量;bestw是当前最优载重量;r是剩余集装箱的重量。
定义上界函数为cw+r。在以z为根的子树中任一叶结点所相应的载重量均不超过cw+r。因此,当cw+r<=bestw时,可将z的右子树剪去。


关于“上界函数”。既然是“以z为根的所有叶结点”都不满意条件。为什么不剪去z的所有子树,返回z上一层?
为什么只剪去z的“右子树”,保留了“左子树”?


例如:

已经搜索到了结点F
此时发现“当前载重量”+“剩余集装箱重量”< “当前最优载重量”
那么就没必要搜索L和M了。为什么书上说只裁剪右子树(M),没说裁剪L?






...全文
190 1 打赏 收藏 转发到动态 举报
写回复
用AI写文章
1 条回复
切换为时间正序
请发表友善的回复…
发表回复
赵4老师 2017-02-21
  • 打赏
  • 举报
回复
代入典型数据,单步运行并观察。

64,632

社区成员

发帖
与我相关
我的任务
社区描述
C++ 语言相关问题讨论,技术干货分享,前沿动态等
c++ 技术论坛(原bbs)
社区管理员
  • C++ 语言社区
  • encoderlee
  • paschen
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
  1. 请不要发布与C++技术无关的贴子
  2. 请不要发布与技术无关的招聘、广告的帖子
  3. 请尽可能的描述清楚你的问题,如果涉及到代码请尽可能的格式化一下

试试用AI创作助手写篇文章吧