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


以深度优先方式系统搜索问题解的算法称为回溯法。在回溯法中,解空间树主要分为了四种子集树、排列树、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);
        }
    }
}

 

 


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM