洛谷P1725 琪露诺 (单调队列/堆优化DP)
显然的DP题.....
对于位置i,它由i-r~i-l的位置转移过来,容易得到方程 dp[i]=dp[i]+max(dp[i−r],...,dp[i−l])。
第一种:n2的暴力,只能拿部分分。
1 #include<bits/stdc++.h>
2 using namespace std;
3 const int N=2e5+5,inf=0x3f3f3f3f;
4 int n,l,r,a[N],dp[N],ans=-inf;
5
6 int main(){
7 scanf("%d%d%d",&n,&l,&r);
8 for(int i=0;i<=n;i++) scanf("%d",&a[i]);
9 memset(dp,-0x3f,sizeof(dp));
10 dp[0]=0;
11 for(int i=l;i<=n+r;i++){
12 for(int j=max(i-r,0);j<=i-l;j++){
13 dp[i]=max(dp[i],dp[j]+a[i]);
14 }
15 if(i>n) ans=max(ans,dp[i]);
16 }
17 cout<<ans;
18 }
注意细节:i从l到n+r枚举,i-r可能为负导致越界,所以取max(i-r,0);
第二种:单调队列优化,max(dp[i−r],...,dp[i−l])就是找这个区间中的最大值,类似于滑动窗口的思想,建立一个单减的队列。
1 #include<bits/stdc++.h>
2 using namespace std;
3 const int N=2e5+5;
4 int dp[N],q[N],a[N],n,l,r,ans=-0x3f3f3f3f;
5
6 int main(){
7 scanf("%d%d%d",&n,&l,&r);
8 for(int i=0;i<=n;i++) scanf("%d",&a[i]);
9 memset(dp,-0x3f,sizeof(dp));
10 dp[0]=0;
11 int h=1,t=0;
12 for(int i=l;i<=n;i++){
13 while(h<=t && dp[q[t]]<=dp[i-l]) t--;
14 q[++t]=i-l;
15 while(h<=t && q[h]<i-r) h++;
16 dp[i]=dp[q[h]]+a[i];
17 }
18 for(int i=n-r+1;i<=n;i++)
19 ans=max(ans,dp[i]);
20 cout<<ans<<endl;
21 }
第三种:堆优化(大根堆),思想和上一种差不多,都是维护区间最大值,(个人感觉堆优化的代码要简单一小小小些)
1 #include<bits/stdc++.h>
2 using namespace std;
3 const int N=2e5+5,inf=0x3f3f3f3f;
4 int n,l,r,dp[N],a[N],ans=-inf;
5 struct node{
6 int p,val;
7 friend bool operator < (node a,node b){
8 return a.val<b.val;//大根堆
9 }
10 };
11 priority_queue<node> q;
12 int main(){
13 scanf("%d%d%d",&n,&l,&r);
14 memset(dp,-0x3f,sizeof(dp));
15 for(int i=0;i<=n;i++) scanf("%d",&a[i]);
16 dp[0]=0;
17 for(int i=l;i<=n;i++){
18 q.push((node){i-l,dp[i-l]});
19 while(q.top().p<i-r) q.pop();
20 dp[i]=q.top().val+a[i];
21 }
22 for(int i=n-r+1;i<=n;i++)
23 ans=max(ans,dp[i]);
24 cout<<ans;
25 }
对于这种题,要写出DP方程,观察式子看能不能使用数据结构来优化,可能优化方式不止一种。
洛谷P1725 琪露诺 (单调队列/堆优化DP)的更多相关文章
- 洛谷P1725琪露诺(单调队列优化dp)
P1725 琪露诺 题目描述 在幻想乡,琪露诺是以笨蛋闻名的冰之妖精.某一天,琪露诺又在玩速冻青蛙,就是用冰把青蛙瞬间冻起来.但是这只青蛙比以往的要聪明许多,在琪露诺来之前就已经跑到了河的对岸.于是琪 ...
- 洛谷 P1725 琪露诺 题解
P1725 琪露诺 题目描述 在幻想乡,琪露诺是以笨蛋闻名的冰之妖精. 某一天,琪露诺又在玩速冻青蛙,就是用冰把青蛙瞬间冻起来.但是这只青蛙比以往的要聪明许多,在琪露诺来之前就已经跑到了河的对岸.于是 ...
- P1725 琪露诺(单调队列优化)
描述:https://www.luogu.com.cn/problem/P1725 小河可以看作一列格子依次编号为0到N,琪露诺只能从编号小的格子移动到编号大的格子.而且琪露诺按照一种特殊的方式进行移 ...
- 洛谷P1725 琪露诺
传送门啦 本人第一个单调队列优化 $ dp $,不鼓励鼓励? 琪露诺这个题,$ dp $ 还是挺好想的对不,但是暴力 $ dp $ 的话会 $ TLE $ ,所以我们考虑用单调队列优化. 原题中说她只 ...
- 洛谷—— P1725 琪露诺
https://www.luogu.org/problem/show?pid=1725 题目描述 在幻想乡,琪露诺是以笨蛋闻名的冰之妖精.某一天,琪露诺又在玩速冻青蛙,就是用冰把青蛙瞬间冻起来.但是这 ...
- Luogu【P1725】琪露诺(单调队列,DP)
本文是笔者第二篇解题报告.从现在开始,会将练的一些题发到博客上并归类到"解题报告"标签中. 琪露诺是这样一道题 这道题可以用纯DP做,但是据说会超时.(为什么?看起来过河这题比它数 ...
- [洛谷P3693]琪露诺的冰雪小屋
题目大意:琪露诺的冰雪小屋,我做的第一道大模拟题. 题解:模拟... 卡点:无数小错误,要是没有写一点调一点,那大概是永远调不出来了... C++ Code: #include <cstdio& ...
- luoguP1725 琪露诺 单调队列
DP 方程:$f[i]=max(f[j])+v[i]$ 转移范围:$i-r<=j<=i-l$ 由此我们得知,每次只有 $[i-r,i-l]$ 部分的 $f$ 值对新更新的答案会有贡献. 故 ...
- P1725 琪露诺
P1725 琪露诺 单调队列优化dp 对于不是常数转移的dp转移,我们都可以考虑单调队列转移 然而我们要把数组开大 #include<cstdio> #include<algorit ...
随机推荐
- SkyWalking分布式系统应用程序性能监控工具-中
其他功能 性能剖析 在系统性能监控方法上,Skywalking 提出了代码级性能剖析这种在线诊断方法.这种方法基于一个高级语言编程模型共性,即使再复杂的系统,再复杂的业务逻辑,都是基于线程去进行执行的 ...
- 1000-ms-HashMap 线程安全安全问题
问题: HashMap是否是线程安全 详解 http://www.importnew.com/21396.html 有源码分析 和代码性能比较 CHM性能最好 HashMap不是线程安全的:Hasht ...
- 安卓手机如何无线连接adb?
一般情况,大家adb调试手机,都是通过数据线的,但这样又是不太方便,所以我们可以通过WLAN来adb. 我的是华为手机,进入:设置-关于手机,连续点击版本号,唤出开发者模式.然后去返回设置-系统和更新 ...
- js实现两种99乘法表
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- Java面试题(二)--MySQL
1 存储引擎 1.简单描述一个Mysql的内部结构? MySQL的基本架构示意图: 大体来说,MySQL可以分为server层和存储引擎层两部分. ① server层包括连接器.查询缓存.分析器.优化 ...
- 使用SSH连接解决git报错:fatal: unable to access 'https://github.com/xxx/xxx.github.io.git/': Proxy CONNECT aborted
TL;DRs 这个错误的原因和HTTPS的代理配置有关,使用SSH方式连接可以避免这一问题 最近git pull和push的时候总是报错 fatal: unable to access 'https: ...
- Java四大引用详解:强引用、软引用、弱引用、虚引用
面试官考察Java引用会问到强引用.弱引用.软引用.虚引用,具体有什么区别?本篇单独来详解 @mikechen Java引用 从JDK 1.2版本开始,对象的引用被划分为4种级别,从而使程序能更加灵活 ...
- Git 06 分支
参考源 https://www.bilibili.com/video/BV1FE411P7B3?spm_id_from=333.999.0.0 版本 本文章基于 Git 2.35.1.2 概述 分支用 ...
- IDEA Git缓慢
有的公司电脑会强制安装一些特定的杀毒软件或者监控软件. 在安装后,我们的 IDEA 可能会出现 Git 相关操作非常缓慢的情况. 虽然用 Git 命令操作不受影响,但终究没有可视化界面直观方便. 解决 ...
- C++ 炼气期之结构体
1. 前言 随着计算机向着不同领域的延伸,数据的概念已经不仅局限于数值型数据,计算机需要处理大量的非数值.且复杂的类型数据. 为了能抽象地描述这些非数值.复杂类型的数据,C++引入了复合数据类型的概念 ...