【算法笔记】 简单二维DP(资源分配 最长公共子序列 区间DP)

这篇博客探讨了如何使用二维动态规划(DP)解决资源分配、计算最长公共子序列以及解决区间DP问题,如石子合并。在资源分配问题中,通过双重循环枚举找到最大化收益的方案。对于最长公共子序列,当字符相等时,直接累加长度,否则取两个方向的最长子序列。在区间DP问题中,通过求解子区间最优解来获取整个区间的最大值。
摘要由CSDN通过智能技术生成

1.资源分配类

要求资源分配的最大值,我们可以用二维数组f[i][j]来表示前i个公司得到j台机器后所得到的最大盈利值。

方程是:

f[i][j]=max(f[i][j],f[i-1][k]+a[i][j-k]);

我们要去枚举每一个i和j,因此用双重循环来解决,k表示第i个公司取的不取机器数,即1~i-1个公司取的机器数;f[i-1][k]表示前i-1个公司取k台机器的最大值,a[i][j-k]表示第i个公司取剩余的k台机器的利益,那么f[i-1][k]+a[i][j-k]表示的就是第i个公司不取k台机器所得到的最大值,当然,k也是用循环来枚举的。

emm.......

有点绕,毕竟我感觉资源分配的博客是我一直相要写的,却一直不知道要怎么表达,因此写的有点绕,也只能在方程的基础上解释一下方程的意义了,那么结合代码也许可以更好理解一些:

#include<bits/stdc++.h>
using namespace std;
int a[1000][1000],f[1000][1000]={},n,m;
int main()
{
   
	cin>>m>>n;
	for (int i=1;i<=n;i++)
	   for (int j=1;j<=m;j++)
	      cin>>a[i][j];
	for (int i=1;i<=n;i++)
	  for (int j=1;j<=m;j++)
	      for (</
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值