博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
洛谷P2858奶牛零食 题解
阅读量:4967 次
发布时间:2019-06-12

本文共 898 字,大约阅读时间需要 2 分钟。

这个题一开始能看出来是一道动态规划的题目,但是并不知道如何写状态转移方程,但是我们可以想一想这个题应该是一道区间DP,而区间DP的特点就是状态转移方程一般跟该区间的左节点和右节点或者中间断点有关,因为我们一次是从两个点中选一个而原题中的a值是(n-(left-right)),因此我们就可以得出状态转移方程

dp[i][j]=max(dp[i][j-1]+data[j]*(n-(j-i)),dp[i+1][j]+data[i]*(n-(j-i)));

知道了这个就完了吗,当然不是,首先我们要预处理出dp[i][i]=data[i]

然后我们再看方程,方程是有j的前一位和i的后一位推出来的,因此我们要让i从后往前推,j从前往后推。所以这个题给我们一个启示,仅仅得出状态转移方程是远远不够的,用什么方式推也很重要。

代码:

#include
#include
#include
#include
#include
using namespace std;int data[1000100],dp[10001][10001],maxn=0;int main() { int n; scanf("%d",&n); for(int i=1;i<=n;i++) scanf("%d",&data[i]),dp[i][i]=data[i]; for(int i=n;i>=1;i--) { for(int j=i;j<=n;j++) dp[i][j]=max(dp[i][j-1]+data[j]*(n-(j-i)),dp[i+1][j]+data[i]*(n-(j-i))); } cout<

 

转载于:https://www.cnblogs.com/liuwenyao/p/9270022.html

你可能感兴趣的文章
HTML5 canvas绘制图形
查看>>
.NET项目ScriptManager, UpdatePanel AND AJAX
查看>>
Dede修改文章默认标题长度,让标题全显示
查看>>
PyTorch教程之Autograd
查看>>
linux环境下jdk的安装步骤
查看>>
sql字符串转换,规定字符串长度,位数不足的在前面或者后面补零
查看>>
409. 最长回文串
查看>>
Java内部类
查看>>
codevs 2597 团伙
查看>>
基于时间的ACl
查看>>
让Elasticsearch飞起来——性能优化实践干货
查看>>
Python知识梳理
查看>>
201621123041java程序设计第四周学习总结
查看>>
数据访问 访问方法的封装
查看>>
HTTP请求header信息讲解
查看>>
腾讯+网易单季手游收80亿,占行业7成
查看>>
减脂相关
查看>>
三、Abstract Factory 抽象工厂(创建型模式)
查看>>
一篇文章看懂大数据分析就业前景及职能定位
查看>>
Spring MVC---基于注解的控制器
查看>>