TYVJ P1078 删数 Label:区间dp
描述
每次操作都有一个操作价值,比如现在要删除从i位置到k位置上的所有的数。操作价值为|xi – xk|*(k-i+1),如果只去掉一个数,操作价值为这个数的值。
任务
如何操作可以得到最大值,求操作的最大价值。
输入格式
3<=N<=100,N个操作数为1..1000 之间的整数。
输出格式
测试样例1
输入
6
54 29 196 21 133 118
输出
768
代码
#include<iostream>
#include<cstdio>
#include<cstring>
#include<cmath>
#include<algorithm>
using namespace std;
int a[],f[][],sum[][];
int N; int get_sum(int l,int r){
if(sum[l][r]>=) return sum[l][r];
else{
int pos=;
pos=abs(a[l]-a[r])*(r-l+);
return pos;
}
} int dp(int l,int r){
if(l==r) return a[l];
if(l+==r){
int pos=;
pos=get_sum(l,r);
pos=max(pos,a[l]+a[r]);
return pos;
}
if(f[l][r]>=) return f[l][r];
for(int k=l+;k<r;k++){//错误代码
f[l][r]=max(f[l][r],dp(l,k) + dp(k+,r));
f[l][r]=max(f[l][r],dp(l,k) + get_sum(k+,r));
f[l][r]=max(f[l][r],get_sum(l,k) + dp(k+,r));
f[l][r]=max(f[l][r],get_sum(l,k) + get_sum(k+,r));
}
return f[l][r];
} int main(){
// freopen("01.txt","r",stdin);
memset(f,-,sizeof(f));
memset(sum,-,sizeof(sum));
scanf("%d",&N);
for(int i=;i<=N;i++) scanf("%d",&a[i]);
printf("%d\n",dp(,N));
return ;
}这个代码没有AC,不知道问题何在,有个点没有过。。。(下文已解决)
我的想法是不管怎么取,所在区域与第几次取是没有关系的。
于是就4种情况。。。//这句话就留着吧,以后明白自己错在哪里
数据如下:
输入
100
169 36 193 11 80 329 155 421 67 222 106 225 175 100 151 227 117 340 129 19 395 292 308 48 89 310 518 302 460 105 355 33 554 455 233 44 293 6 295 7 161 164 556 435 71 402 221 353 203 311 324 217 520 511 108 26 373 13 95 241 230 162 403 258 365 20 326 8 218 176 206 516 120 351 275 157 350 103 330 204 90 187 451 167 104 418 541 215 349 214 294 426 216 212 420 111 121 424 283 22输出
51206
补充
找到错误了:上述代码没有考虑只有右边取一个的情况,只要把dp条件中k=l+1改为k=l就可以
这个错误犯了好几次了,刚才思考了一下,应该是这个问题,于是过了
附代码
#include<iostream>
#include<cstdio>
#include<cstring>
#include<cmath>
#include<algorithm>
using namespace std;
int a[],f[][],sum[][];
int N; int get_sum(int l,int r){
if(sum[l][r]>=) return sum[l][r];
else{
int pos=;
pos=abs(a[l]-a[r])*(r-l+);
return pos;
}
} int dp(int l,int r){
if(l==r) return a[l];
if(l+==r){
int pos=;
pos=get_sum(l,r);
pos=max(pos,a[l]+a[r]);
return pos;
}
if(f[l][r]>=) return f[l][r];
for(int k=l;k<r;k++){//这里被修改了
f[l][r]=max(f[l][r],dp(l,k) + dp(k+,r));
f[l][r]=max(f[l][r],dp(l,k) + get_sum(k+,r));
f[l][r]=max(f[l][r],get_sum(l,k) + dp(k+,r));
f[l][r]=max(f[l][r],get_sum(l,k) + get_sum(k+,r));
}
return f[l][r];
} int main(){
// freopen("01.txt","r",stdin);
memset(f,-,sizeof(f));
memset(sum,-,sizeof(sum));
scanf("%d",&N);
for(int i=;i<=N;i++) scanf("%d",&a[i]);
printf("%d\n",dp(,N));
return ;
}
再补充更优代码:
#include<iostream>
#include<cstdio>
#include<cstring>
#include<cmath>
#include<algorithm>
using namespace std;
int sum[][],f[][],a[],N;
int get_sum(int l,int r){
if(sum[l][r]>=) return sum[l][r];
if(l==r) return sum[l][r]=a[l];
else return sum[l][r]=abs(a[l]-a[r])*(r-l+);
} int dp(int l,int r){
if(f[l][r]>=) return f[l][r];
f[l][r]=get_sum(l,r);//最开始也类似这样的思路,但是没写这句话,
//导致没有考虑到一次全删的情况
for(int k=l;k<r;k++){
f[l][r]=max(f[l][r], get_sum(l,k) + dp(k+,r));
f[l][r]=max(f[l][r], dp(l,k) +get_sum(k+,r));
}
return f[l][r];
} int main(){
// freopen("01.txt","r",stdin);
memset(f,-,sizeof(f));
memset(sum,-,sizeof(sum)); scanf("%d",&N);
for(int i=;i<=N;i++) scanf("%d",&a[i]); printf("%d\n",dp(,N));
return ;
}片段一:
f[l][r]=max(f[l][r],dp(l,k) + dp(k+,r));
f[l][r]=max(f[l][r],dp(l,k) + get_sum(k+,r));
f[l][r]=max(f[l][r],get_sum(l,k) + dp(k+,r));
f[l][r]=max(f[l][r],get_sum(l,k) + get_sum(k+,r));讲一下存在的问题:
1)dp开始时应该对该状态进行初始化,比如补充代码第十六行(片段二)
片段二:
f[l][r]=get_sum(l,r);//最开始也类似这样的思路,但是没写这句话,
//导致没有考虑到一次全删的情况2)片段一第一行代码无用,本来就会考虑到
3)第四行基本上就等同于片段二 ,还绕了个弯
总结起来就是dp应该理解自己要递归什么,然后写完不急调样例,
在脑海中过一遍代码历程,检查是否有状态没有考虑到
再讲一句:sum数组有开45ms,没开60ms
但是如果f数组没开的话就呵呵了
TYVJ P1078 删数 Label:区间dp的更多相关文章
- TYVJ 矩阵取数 Label:高精度+dp
题目描述 帅帅经常跟同学玩一个矩阵取数游戏:对于一个给定的n*m的矩阵,矩阵中的每个元素aij均为非负整数.游戏规则如下: 1.每次取数时须从每行各取走一个元素,共n个.m次后取完矩阵所有元素: 2. ...
- tyvj 1198 矩阵连乘——区间dp
tyvj 1198 矩阵连乘 题目描述 一个n*m矩阵由n行m列共n*m个数排列而成.两个矩阵A和B可以相乘当且仅当A的列数等于B的行数.一个N*M的矩阵乘以一个M*P的矩阵等于一个N*P的矩阵,运算 ...
- Vijos 1451 圆环取数 【区间DP】
背景 小K攒足了路费来到了教主所在的宫殿门前,但是当小K要进去的时候,却发现了要与教主守护者进行一个特殊的游戏,只有取到了最大值才能进去Orz教主…… 描述 守护者拿出被划分为n个格子的一个圆环,每个 ...
- P1005 矩阵取数游戏[区间dp]
题目描述 帅帅经常跟同学玩一个矩阵取数游戏:对于一个给定的\(m*n\)的矩阵,矩阵中的每个元素\(a_{i,j}\)均为非负整数.游戏规则如下: 每次取数时须从每行各取走一个元素,共n个.经过m次后 ...
- TYVJ P1047 乘积最大 Label:dp
背景 NOIP 2000 普及组 第三道 描述 今年是国际数学联盟确定的“2000——世界数学年”,又恰逢我国著名数学家华罗庚先生诞辰90周年.在华罗庚先生的家乡江苏金坛,组织了一场别开生面的数学智力 ...
- 1166 矩阵取数游戏[区间dp+高精度]
1166 矩阵取数游戏 2007年NOIP全国联赛提高组 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 黄金 Gold 题解 题目描述 Description [ ...
- TYVJ P1075 硬币游戏 Label:dp
背景 农民John的牛喜欢玩硬币,所以John就为它们发明了一个新的两人硬币游戏,叫做Xoinc. 描述 最初地面上有一堆n个硬币(5<=n<=2000),从上面数第i个硬币的价值为C_i ...
- P1005 矩阵取数游戏 区间dp 高精度
题目描述 帅帅经常跟同学玩一个矩阵取数游戏:对于一个给定的n \times mn×m的矩阵,矩阵中的每个元素a_{i,j}ai,j均为非负整数.游戏规则如下: 每次取数时须从每行各取走一个元素,共n ...
- 「LuoguP1430」 序列取数(区间dp
题目描述 给定一个长为n的整数序列(n<=1000),由A和B轮流取数(A先取).每个人可从序列的左端或右端取若干个数(至少一个),但不能两端都取.所有数都被取走后,两人分别统计所取数的和作为各 ...
随机推荐
- DICOM医学图形处理:storescp.exe与storescu.exe源码剖析,学习C-STORE请求(续)
转载:http://blog.csdn.net/zssureqh/article/details/39237649 背景: 上一篇博文中,在对storescp工具源文件storescp.cc和DcmS ...
- python4delphi import lxml pandas 出错的小结
环境: 1.win10 64位 2.delphi xe8 3.python2.7 4.python4delphi (svn 2015-03-21 发布的83版本号) 5.lxml 3.4.4(通过p ...
- emu1
第一题 一个很奇怪的贪心.先排序一遍,再扫描一遍,能加入尽量加入,不能加入就一定不能加入..由于每次都在可能的最早时间加入一个数可以保证差最小?反正差不多这样了. O(n log n) #includ ...
- Solr5.3.1整合IKAnalyzer
由于solr5.3.1本身不支持中文分词,而msseg4j的分词效果不明显.因而采用IK进行分词,然而参考http://www.superwu.cn/2015/05/08/2134/在google上下 ...
- iOS 查看系统字体效果的网页
常常需要查看字体的样式,这里推荐一个网页http://iosfonts.com,方便查阅.
- mybatis There is no getter for property named 'xx' in 'class java.lang.String
转载自://http://www.cnblogs.com/anee/p/3324140.html 用mybatis查询时,传入一个字符串传参数,且进行判断时,会报 There is no getter ...
- 解决Exception in thread "main" java.lang.UnsupportedClassVersionError: org/apache/maven/cli/MavenCli : Unsupported major.minor version 51.0
jdk问题 解决方案: 更换IDE的jdk
- 《数学之美》(吴军 著)读书笔记:第1章 文字和语言 vs 数字和信息
第1章有4个小节,以及前言. 前言 1.信息 2.文字和数字 3.文字和语言背后的数学 4.小结 下面我一一展开,让我们看看每一节都说了什么. 前言 语言和数字都是信息传播的载体,他们之间其实存在着天 ...
- 面向服务的体系结构(SOA)——(5)关于MEP(Message Exchange Patterns)
SOA中的MEP和JavaEE中的JMS类似,当然了就应该是类似的,因为都是关于消息方面的.一个是对系统架构当中消息的解决思路,一个是针对Java平台中的消息的具体解决办法(严格说不是具体的,只是提供 ...
- Office Word 2013发布带数学公式的博客
今日在自学冈萨雷斯的<数字图像处理>一书,想做笔记来记录,并分享一些MATLAB代码,又加上刚刚注册博客园的账户,便想着如何能够较为方便的来书写博客.本文主要涉及到的问题有: 如何用wor ...