博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
回溯法算法框架
阅读量:4606 次
发布时间:2019-06-09

本文共 1185 字,大约阅读时间需要 3 分钟。

回溯法:有通用解题法 之称,可以系统的搜索一个问题的所有解和任一解,是一个既带有系统性,又带有跳跃性的搜索算法。

算法基本思想:

  确定解空间后

  从开始节点出发,以深度优先的方式搜索整个解空间。

  如果当前扩展结点不能再向纵深方向移动,当前节点为死节点。此时,应该往回移动至最近的一个活节点处。,并是这个或节点成为当前节点的扩展结点。

提高算法方式(剪枝函数)

  1 用约束函数在扩展结点出剪去不满足约束的子树

  2 用限界函数剪去得不到最优解的子树。

回溯法解题步骤:

  1 定义问题的解空间

  2 确定易于搜索的解空间结构

  3 以深度优先方式搜索解空间,并在搜索过程中用剪枝函数避免无效搜索。

递归回溯:

void Backtrack(int t){    if(t>n)        Output(x);    else        for(int i=f(n,t);i<=(g,t);i++)        {            x[t] = h(i);            if(Constraint(t) && Bound(t))                Backtrack(t+1);        }}

子集树:

当所有的问题是从n个元素的集合S中找出满足某种性质的子集时,相应的解空间树称为子集树。

伪码为:

void Backtrack(int t){    if(t>n)        Output(x);    else        for(int i=f(n,t);i<=(g,t);i++)        {            x[t] = h(i);            if(Constraint(t) && Bound(t))                Backtrack(t+1);        }}

排列树:

当所给的问题是确定n个元素满足某种性质的排列时,相应的解空间树称为排列数。

伪码为:

void Backtrack(int t){    if(t>n)        Output(x);    else        for(int i=f(n,t);i<=(g,t);i++)        {            Swap(x[t],x[i]);            if(Constraint(t) && Bound(t))            {                Backtrack(t+1);            }            Swap(x[t],x[i]);        }}

转载于:https://www.cnblogs.com/xing901022/archive/2012/10/22/2734101.html

你可能感兴趣的文章
设计模式学习笔记——Prototype原型模式
查看>>
pom.xml里有红叉报错的解决办法
查看>>
Perl last和next的用法区别
查看>>
Selenium 管理 Cookies
查看>>
exceptionfunction[LeetCode]Permutations
查看>>
Linux(2)_常用命令2
查看>>
自定义分页
查看>>
[转]DELPHI——调试(1)
查看>>
JS秒数转成分秒时间格式
查看>>
xp_cmdshell 命令的开启与关闭,和状态查询
查看>>
Linux sudoers
查看>>
MySQL详解(18)-----------分页方法总结
查看>>
bzoj 4595 激光发生器
查看>>
multi cookie & read bug
查看>>
js时间转换
查看>>
(转载) Android Studio你不知道的调试技巧
查看>>
POJ2231 Moo Volume 递推 C语言
查看>>
struts2类型转换的具体流程
查看>>
Hdu 1203 I NEED A OFFER!
查看>>
php文件上传类
查看>>