1.常见的四种算法
- 贪心算法
- 分治思想(递归算法)
- 动态规划
- 穷举思想
2.贪心算法
1.算法思想
假设一个问题比较复杂,暂时找不到全局最优解,那么我们可以考虑把原问题拆成几个小问题(分而治之思想),分别求每个小问题的最优解,再把这些“局部最优解”叠起来,就“当作”整个问题的最优解了。
2.基本步骤
- 明确到底什么是最优解?
- 明确什么是子问题的最优解?
- 分别求出子问题的最优解再堆叠出全局最优解?
3.前提条件
- 原问题复杂度过高;
- 求全局最优解的数学模型难以建立;
- 求全局最优解的计算量过大;
- 没有太大必要一定要求出全局最优解,“比较优”就可以。
4.问题分类
按串行任务分:按子任务来分解,即每一步都是在前一步的基础上再选择当前的最优解
按规模递减分:规模较大的复杂问题,可以借助递归思想,分解成一个规模小一点点的问题,循环解决,当最后一步的求解完成后就得到了所谓的“全局最优解”。
按并行任务分:这种问题的任务不分先后,可能是并行的,可以分别求解后,再按一定的规则(比如某种配比公式)将其组合后得到最终解。
参看链接