算法第五章 | 回溯算法

一、 回溯算法

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

它在问题的解空间树中,按深度优先策略,从根节点出发搜索解空间树。算法搜索至解空间树的任一结点时,先判断该结点是否包含问题的解。如果肯定不包含,则跳过对以该结点为根的子树的搜索,逐层向其祖先结点回溯。否则,进入该子树,继续按深度优先策略搜索。回溯法求问题的所有解时,要回溯到根,且根结点的所有子树都已被搜索遍才结束。回溯法求问题的一个解时,只要搜索到问题的一个解就可结束。

这种以深度优先方式系统搜索问题的解的搜索问题解的算法称为回溯法,它适用于组合数较大的问题。

1.问题的解空间

用回溯法解问题时,应明确定义问题的解空间,问题的解空间至少应包含问题的一个(最优)解。

定义了问题的解空间后,还应将解空间很好地组织起来,使得能用回溯法方便地搜索整个解空间。通常将解空间组织成树或图的形式。

例:n=3时的0-1背包问题,可用一棵完全二叉树表示其解空间。

(图) 0-1背包的解空间树

2.回溯法的基本思想

确定了解空间的组织结构后,回溯法从开始结点(根结点)出发,以深度优先方式搜索整个解空间。这个开始结点成为活结点,同时也成为当前的扩展结点。在当前的扩展结点处,搜索向纵深方向移至一个新节点。该新节点成为新的活结点,并成为当前扩展结点。如果在当前的扩展结点出不能再向纵深方向移动,则当前扩展就成为死结点。此时,应往回移动(回溯)至最近的一个活结点处,并使这个活结点成为当前的扩展结点。回溯法以这种工作方式递归地在解空间中搜索,直至找到所要求的解或解空间中已无活点为止。

3.约束函数

回溯法搜索解空间时,通常采用两种策略避免无效搜索,提高回溯法的搜索效率。

其一是用约束函数在扩展结点处剪去不满足约束的子树。

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

这两类函数统称为剪枝函数。

二、 “子集和”问题的解空间结构和约束函数

1.问题描述:设集合S={x1,x2,…,xn}是一个正整数集合,c是一个正整数,子集和问题判定是否存在S的一个子集S1,使S1中的元素之和为c。试设计一个解子集和问题的回溯法。

2.解空间结构:

(图)解空间结构

3.约束函数:

If (c < sum) {v[p] = false; sum-= data[p];}

4.具体代码如下:

bool traceback(int n) {
    int p = 0, sum = 0;
    while (p >= 0) {
        if (!v[p]) {
            v[p] = true;
            sum += data[p];
            if (c == sum)
                return true;
            else if (c < sum) {
                v[p] = false;
                sum -= data[p];
            }
            p++;
        }
        if (p >= n) {
            while (v[p - 1]) {
                p--;
                v[p] = false;
                if (p<1) return false;
            }
            while (!v[p - 1]) {
                p--;
                if (p<1) return false;
            }
            sum -= data[p - 1];
            v[p - 1] = false;
        }
    }
    return false;
}

三、 学习过程中遇到的问题及结对编程情况

1.实现回溯算法的能力有待提高。

2.未能熟练掌握套子集数模板的能力。

3.与队友交流过模板及剪枝的问题。

原文地址:https://www.cnblogs.com/ljl-gd/p/10137145.html

时间: 2024-10-09 23:26:32

算法第五章 | 回溯算法的相关文章

算法第五章小结

一.回溯算法的概念以及理解 概念:回溯法(探索与回溯法)是一种选优搜索法,又称为试探法,按选优条件向前搜索,以达到目标. 理解:在回溯法中,每次扩大当前部分解时,都面临一个可选的状态集合,新的部分解就通过在该集合中选择构造而成.这样的状态集合,其结构是一棵多叉树,每个树结点代表一个可能的部分解,它的儿子是在它的基础上生成的其他部分解.树根为初始状态,这样的状态集合称为状态空间树. 二.“子集和”问题的解空间结构和约束函数 1.解空间结构 非负非零的整数集合 S = {x1, x2, …, xn}

算法第五章上机实践

实践题目 工作分配问题 问题描述 有n个人.n个工作,每个人只能做一个工作,每人对应每个工作有一个消费,求完成所有工作的最小消费 算法描述 这里采用回溯法,按顺序给每个人分配工作,如果一件工作已经被分配,打上标记防止被重复分配 分配过程中,如果当前的消费已经大于等于已知的最小消费,就停止对子节点的搜索. 心得体会 实际上这题还有优化空间和另外的解法. 可以用课本的方法通过排列组合来剪枝. 了解到的另外两种解法(本质上一样): 二分图完全匹配算法(匈牙利算法) 网络流--最小费用流(最小费用流也可

算法第五章上机实践报告

一 . 实践题目 7-2 工作分配问题 二 . 问题描述 设有n件工作分配给n个人.将工作i分配给第j个人所需的费用为cij . 设计一个算法,对于给定的工作费用,为每一个人都分配1 件不同的工作,并使总费用达到最小. 输入格式: 输入数据的第一行有1 个正整数n (1≤n≤20).接下来的n行,每行n个数,表示工作费用. 输出格式: 将计算出的最小总费用输出到屏幕. 输入样例: 3 10 2 3 2 3 4 3 4 5 输出样例: 9 三 . 算法描述 1. 解空间 第一个人选择第几个工作,第

算法第五章实践

一 . 实践题目 工作分配问题 二 . 问题描述 设有n件工作分配给n个人.将工作i分配给第j个人所需的费用为cij . 设计一个算法,对于给定的工作费用,为每一个人都分配1 件不同的工作,并使总费用达到最小. 输入格式: 输入数据的第一行有1 个正整数n (1≤n≤20).接下来的n行,每行n个数,表示工作费用. 输出格式: 将计算出的最小总费用输出到屏幕. 输入样例: 3 10 2 3 2 3 4 3 4 5 输出样例: 9 三 .算法描述 进行回溯,遍历左子树后回溯遍历右子树 if(cp+

算法第五章实践报告

1. 实践题目 工作分配问题 2. 问题描述 设有n件工作分配给n个人.将工作i分配给第j个人所需的费用为cij . 设计一个算法,对于给定的工作费用,为每一个人都分配1 件不同的工作,并使总费用达到最小. 输入格式: 输入数据的第一行有1 个正整数n (1≤n≤20).接下来的n行,每行n个数,表示工作费用. 输出格式: 将计算出的最小总费用输出到屏幕. 输入样例: 在这里给出一组输入.例如: 3 10 2 3 2 3 4 3 4 5 输出样例: 在这里给出相应的输出.例如:   9 3. 算

机器学习算法概述第五章——CART算法

特点: 是一个二叉树,元素可以重复利用,可以做回归也可以做分类,分类用最小二乘法,即误差平方和最小 切割方法: 对于可量化的x来说: 切割点通常为两个x的平均值 左右两部分分别取均值,再评判以哪个分割点的误差平方和最小,即第一层根节点为此点 以此为规则,往下迭代,构建出回归树 对于不可量化的x来说: x无法去均值.直接以特征属性割分,再计算两个区域的均值,再寻找误差平方和最小的切割点 举个栗子: CART回归树的构建: 优点: 易于解释 处理类别特征,其他的技术往往要求数据属性的单一 延展到多分

第五章-回溯法

首先,溯字:(su:4声). 学习要点: 回溯法概述 典型示例 效率分析 1.回溯法概述 问题的解空间.两类典型的解空间 解向量:问题的解可以表示成n元(x1, x2, ..., xn)的解向量形式. 而解空间是指:由于xi的不同取值,而组成的所有解向量.解空间树:若xi有Si种取值,则最后一层(第n层)包含S1*S2*...*Sn个叶结点--和解空间一样,表示问题的所有可能解. 可行解:解空间中,满足约束条件(显约束.隐约束)的解向量(我们应该寻求最优解).其中显约束:即每个xi的取值范围.隐

【算法导论第二章】算法基础

2.1插入排序 扑克牌这个栗子不错.以后得多用扑克牌来形象化思考排序问题. 根据伪代码用java实现插入排序 package com.panjn.java; /** * Created by panjianning on 2016/7/10. */ public class InsertionSort { public static void main(String[] args) { int[] array = new int[]{1, 3, 5, 7, 9, 2, 4, 6, 8, 10};

对回溯算法的理解

一.对回溯算法的理解 应用回溯算法的三个步骤: 1.首先得构造解空间树:子集树和排列树: 2.以深度优先的方式搜索解空间:递归或迭代: 3.设计剪枝函数避免无效搜索:使用约束函数,剪去不满足约束条件的路径或使用限界函数,剪去不能得到最优解的路径. 回溯法解问题的一个显著特征是,解空间树是虚拟的,在任何时候,只需保存从根节点到当前扩展结点的路径. 在回溯问题中,若要求问题的所有解,就要回溯到根. 二.请说明“子集和”问题的解空间结构和约束函数 子集和问题: 设集合S={x1,x2,…,xn}是一个