美文网首页
五大算法思想介绍

五大算法思想介绍

作者: 進撃的Friday | 来源:发表于2018-06-29 11:45 被阅读0次

一、递归与分治

递归算法:直接或者间接不断反复调用自身来达到解决问题的方法。这就要求原始问题可以分解成相同问题的子问题。示例:阶乘、斐波纳契数列、汉诺塔问题

斐波纳契数列:又称黄金分割数列,指的是这样一个数列:1、1、2、3、5、8、13、21、……在数学上,斐波纳契数列以如下被以递归的方法定义:F1=1,F2=1,Fn=F(n-1)+F(n-2)(n>2,n∈N*))。

分治算法:待解决复杂的问题能够简化为几个若干个小规模相同的问题,然后逐步划分,达到易于解决的程度。

1、将原问题分解为n个规模较小的子问题,各子问题间独立存在,并且与原问题形式相同

2、递归的解决各个子问题

3、将各个子问题的解合并得到原问题的解

示例:棋盘覆盖、找出伪币、求最值

棋盘覆盖:在一个(2^k)*(2^k)个方格组成的棋盘上,有一个特殊方格与其他方格不同,称为特殊方格,称这样的棋盘为一个特殊棋盘。要求对棋盘的其余部分用L型方块填满

二、动态规划

动态规划与分治法相似,都是组合子问题的解来解决原问题的解,与分治法的不同在于:分治法的子问题是相互独立存在的,而动态规划应用于子问题重叠的情况。

动态规划方法通常用来求解最优化问题,这类问题可以有很多可行解,每个解都有一个值,找到具有最优值的解称为问题的一个最优解,而不是最优解,可能有多个解都达到最优值。

设计动态规划算法的步骤:

1、刻画一个最优解的结构特征

2、递归地定义最优解的值

3、计算最优解的值,通常采用自底向上的方法

4、利用算出的信息构造一个最优解

示例:0-1背包问题,钢条切割问题等。

三、贪心算法

贪心算法是就问题而言,选择当下最好的选择,而不从整体最优考虑,通过局部最优希望导致全局最优。

贪心算法的要素

1)贪心选择性质:可以通过局部最优选择来构造全局最优解。换言之,直接做出在当前问题中看来最优的选择,而不必考虑子问题的解。

2)最优子结构:一个问题的最优解包含其子问题的最优解。

贪心算法的设计步骤:

1)将最优化问题转换为这样的形式:对其做出一次选择后,只剩下一个子问题需要求解

2)证明做出贪心选择后,原问题总是存在最优解,即贪心选择总是安全的

3)证明做出贪心选择后,剩余的子问题满足性质:其最优解与贪心选择组合即可得到原问题的最优解,这样就得到了最优子结构。

示例:背包问题,均分纸牌,最大整数

四、回溯法

回溯法是一种搜索算法,从根节点出发,按照深度优先搜索的策略进行搜索,到达某一节点后 ,探索该节点是否包含该问题的解,如果包含则进入下一个节点进行搜索,若是不包含则回溯到父节点选择其他支路进行搜索。

回溯法的设计步骤:

1)针对所给的原问题,定义问题的解空间

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

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

示例:0-背包问题、旅行商问题、八皇后问题

五、分支限界法

和回溯法相似,也是一种搜索算法,但回溯法是找出问题的许多解,而分支限界法是找出原问题的一个解。或是在满足约束条件的解中找出使某一目标函数值达到极大或极小的解,即在某种意义下的最优解

在当前节点(扩展节点)处,先生成其所有的儿子节点(分支),然后再从当前的活节点(当前节点的子节点)表中选择下一个扩展节点。为了有效地选择下一个扩展节点,加速搜索的进程,在每一个活节点处,计算一个函数值(限界),并根据函数值,从当前活节点表中选择一个最有利的节点作为扩展节点,使搜索朝着解空间上有最优解的分支推进,以便尽快地找出一个最优解。

分支限界法:

1)FIFO分支限界法

3)优先队列分支限界法:按照优先队列中规定的优先级选取优先级最高的节点成为当前扩展节点。

示例:装载问题,旅行售货员问题


转载自:https://www.cnblogs.com/bulingpan/p/6416362.html

相关文章

  • 五大算法思想介绍

    一、递归与分治 递归算法:直接或者间接不断反复调用自身来达到解决问题的方法。这就要求原始问题可以分解成相同问题的子...

  • Glide解析(一) - LruCache

    本文介绍的内容有 LruCache算法思想介绍 v4包中LruCache中源码解析 LruCache算法思想介绍 ...

  • 算法与数据结构

    五大常用算法之一:分治算法 五大常用算法之二:动态规划算法 五大常用算法之三:贪心算法 五大常用算法之四:回溯法 ...

  • GraphX Label Propagation算法改进

    label propagation算法介绍 标签传播算法(label propagation)的核心思想非常简单:...

  • 字符串匹配 - KMP算法

    前面我们介绍非常高效的 BM 算法,今天我们介绍另一个非常出名且高效的 KMP 算法。 KMP 算法思想 KMP ...

  • 09《算法入门教程》分治算法

    1. 前言 本节内容是分治算法系列之一:分治算法的介绍,主要介绍了分治算法的定义及基本思想和实现策略,然后我们介绍...

  • 机器学习(8)——其他聚类

    层次聚类 紧接上章,本章主要是介绍和K-Means算法思想不同而的其他聚类思想形成的聚类算法。 k-means算法...

  • LFM隐因子算法理解

    一、推荐算法介绍 (一)背景知识 1. 推荐算法分类 推荐算法通常被分为五大类,再加上高级非传统方法,形成5+1 ...

  • JVM - 垃圾回收算法

    JVM - 垃圾回收算法 这里只介绍垃圾回收算法的思想,不关注具体的算法细节垃圾回收算法发展已经有很长的历史 问题...

  • 机器学习系列(六)——knn算法原理与scikit-learn底

    KNN算法 本篇将介绍knn算法,knn算法因为思想非常简单,运用的数学知识比较浅显,是非常适合机器学习入门的算法...

网友评论

      本文标题:五大算法思想介绍

      本文链接:https://www.haomeiwen.com/subject/ewtayftx.html