码迷,mamicode.com
首页 > 编程语言 > 详细

算法设计与分析——回溯法算法模板

时间:2019-12-09 21:13:28      阅读:182      评论:0      收藏:0      [点我收藏+]

标签:pre   种子   深度   方式   swap   awl   color   旅行   符号   

以深度优先方式系统搜索问题解的算法称为回溯法。在回溯法中,解空间树主要分为了四种子集树、排列树、n叉树和不确定树。

在《算法设计与分析课本》中介绍了11个回溯法的问题样例,这里根据解空间树的类型做一个分类。

子集树

装载问题

符号三角形问题

0-1背包问题

最大团问题

 

算法模板:

void backtrack(int t)
{
    if(搜索到叶子结点)
    {
        return;
    }
    for(i=0; i<=1; i++) //01二叉树
    {
        if(满足约束函数和限界函数)//剪枝
        {
            backtrack(t+1);
        }
    }
}

排列树

批处理作业调度

旅行售货员问题

圆排列问题

电路板排列问题

 

算法模板:

void backtrack(int t)
{
    if(搜索到叶子结点)
    {
        return;
    }
    for(i=0; i<=n; i++)
    {
        if(满足约束函数和限界函数)//剪枝
        {
            swap(x[t],x[i]);
            backtrack(t+1);
            swap(x[t],x[i]);
        }
    }
}

n叉树

n后问题

图的m着色问题

 

算法模板:

void backtrack(int t)
{
    if(搜索到叶子结点)
    {
        return;
    }
    for(i=1; i<=n; i++) //n叉树
    {
        x[t]=i;//例如n后问题中,记录第t后所在的第i列
        if(满足约束函数和限界函数)//剪枝
        {
            backtrack(t+1);
        }
    }
}

不确定树

连续邮资问题

 

算法模板:

void backtrack(int t)
{
    if(搜索到叶子结点)
    {
        return;
    }
    for(i=x; i<=y; i++) //x与y由相应的函数得到
    {
        x[t]=i;
        if(满足约束函数和限界函数)//剪枝
        {
            backtrack(t+1);
        }
    }
}

 

 

算法设计与分析——回溯法算法模板

标签:pre   种子   深度   方式   swap   awl   color   旅行   符号   

原文地址:https://www.cnblogs.com/wkfvawl/p/12013129.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!