算法:动态规划

动态规划的概念:

是求解决策过程(decision process)最优化的数学方法。20世纪50年代初美国数学家R.E.Bellman等人在研究多阶段决策过程(multistep decision process)的优化问题时,提出了著名的最优化原理(principle of optimality),把多阶段过程转化为一系列单阶段问题,利用各阶段之间的关系,逐个求解,创立了解决这类过程优化问题的新方法——动态规划


动态规划的分类:

动态规划一般可分为线性动规,区域动规,树形动规,背包动规四类。

  • 线性动规:拦截导弹,合唱队形,挖地雷,建学校,剑客决斗等;
  • 区域动规:石子合并, 加分二叉树,统计单词个数,炮兵布阵等;
  • 树形动规:贪吃的九头龙,二分查找树,聚会的欢乐,数字三角形等;
  • 背包问题:01背包问题,完全背包问题,分组背包问题,二维背包,装箱问题,挤牛奶(同济ACM第1132题)等;

动态规划的核心:

动态规划算法的核心是记住已经求过的解,记住求解的方式有两种:①自顶向下的备忘录法 ②自底向上。 
为了说明动态规划的这两种方法,举一个最简单的例子:求斐波拉契数列Fibonacci 。先看一下这个问题

先看c语言版本的:

public int fib(int n)
{
    if(n<=0)
        return 0;
    if(n==1)
        return 1;

    //其他
    return fib( n-1)+fib(n-2);
}

当我们输入6的时候,输出的8,执行递归树如下:

能看到执行的过程中节点数被重复调用,而动态规划就是将这些调用次数减少,在执行的时候把执行过的子节点保存起来,后面要用到的时候直接查表调用的话可以节约大量的时间

更多了解:

https://blog.csdn.net/baidu_28312631/article/details/47418773

https://blog.csdn.net/baidu_28312631/article/details/47426445

 

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值