lesson99-lesson105 动态规划

本文介绍了动态规划的概念,将其比作"洪湖水浪打浪"的递推过程,并阐述了动态规划作为运筹学分支,通过状态转移方程解决多阶段问题的方法。文章提到了动态规划的递归和递推两种写法,并提及北京大学郭炜教授的相关课程内容。最后,给出了四个动态规划相关的练习题目。
摘要由CSDN通过智能技术生成

作者:兰州锝TC

学习资源

2个可以查询编程语言语法的网站:
1.菜鸟教程
2.w3school

2.17日题解

  • 待更新

往日内容

今日内容:动态规划

  • “洪湖水浪打浪,新浪盖旧浪,旧浪死在沙滩上。”这一场景,非常类似我们解决问题的递推方法(关于递推,后面有介绍)。递推就是按照递推公式不断往前求解的过程,对于当前,只有一个状态描述当前的值。若某些问题并非由一个状态而是由多个状态不断推导,那么这种方法就是动态规划(Dynamic Programming),简称DP。动态规划是运筹学的一个分支,是将问题分解成各个阶段,由相邻两个阶段根据状态转移方程推导求解的一种方法。
  • 什么是动态规划

在这里插入图片描述
在这里插入图片描述- 动态规划的递归写法
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述- 动态规划的递推写法
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述- 数塔问题的程序:

#include<iostream>
#include<algorithm>
using namespace std;
const int maxn=1000;
int f[maxn][maxn],dp[maxn][maxn];
int main()
{
	int n;
	cin>>n;
	for(int i=1;i<=n;i++){
		for(int j=1;j<=i;j++){
			cin>>f[i][j];   //输入数塔 
		}
	}
	//边界 
	for(int j=1;j<=n;j++){
		dp[n][j]=f[n][j];
	}
	//从第n-1层不断往上计算出dp[i][j]
	for(int i=n-1;i>=1;i--){
		for(int j=1;j<=i;j++){
			dp[i][j]=max(dp[i+1][j],dp[i+1][j+1])+f[i][j];
		}
	} 
	cout<<dp[1][1]<<endl;  //输出结果dp[1][1]
	return 0; 
}

对应慕课

在这里插入图片描述

今日练习

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值