分支定界的一般描述
来自维基百科的分支和绑定:
此步骤称为修剪,通常通过维护一个全局变量m(在树的所有节点之间共享)来实现,该变量记录迄今为止检查的所有子区域中看到的最小上限。任何下界大于m的节点都可以被丢弃。
实际例子:旅行推销员问题
旅行商问题的一个简单解决方案是保留一个变量,例如best
,它表示迄今为止发现的最短哈密顿回路(上限)。
每次我们考虑潜在的新电路中的新步骤时,我们都会计算当前点的路径成本,例如cost
,这是该路径成本的下限,并将其与best
变量进行比较。如果在任何时候cost >= best
,我们都不需要考虑这条路径;我们可能会修剪以该子路径开头的所有潜在路径。
这在诸如 C 之类的过程语言中实现起来并不难,我们可以在其中创建一个在函数范围内的变量。例如,
int best = -1; // no best path yet
node* solveTSP() {
// best can be consulted and has a consistent
// value across all recursive calls to solveTSP()
...
}
我的实际问题
我不清楚这种算法将如何纯粹从功能上实现。有没有办法模拟维基百科定义中提到的全局变量m ?
我知道在 Lisp 中拥有一个全局变量很简单,但是在更纯粹的函数式语言(如 Haskell)中这是否可能?