显然的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)的更多相关文章

  1. 洛谷P1725琪露诺(单调队列优化dp)

    P1725 琪露诺 题目描述 在幻想乡,琪露诺是以笨蛋闻名的冰之妖精.某一天,琪露诺又在玩速冻青蛙,就是用冰把青蛙瞬间冻起来.但是这只青蛙比以往的要聪明许多,在琪露诺来之前就已经跑到了河的对岸.于是琪 ...

  2. 洛谷 P1725 琪露诺 题解

    P1725 琪露诺 题目描述 在幻想乡,琪露诺是以笨蛋闻名的冰之妖精. 某一天,琪露诺又在玩速冻青蛙,就是用冰把青蛙瞬间冻起来.但是这只青蛙比以往的要聪明许多,在琪露诺来之前就已经跑到了河的对岸.于是 ...

  3. P1725 琪露诺(单调队列优化)

    描述:https://www.luogu.com.cn/problem/P1725 小河可以看作一列格子依次编号为0到N,琪露诺只能从编号小的格子移动到编号大的格子.而且琪露诺按照一种特殊的方式进行移 ...

  4. 洛谷P1725 琪露诺

    传送门啦 本人第一个单调队列优化 $ dp $,不鼓励鼓励? 琪露诺这个题,$ dp $ 还是挺好想的对不,但是暴力 $ dp $ 的话会 $ TLE $ ,所以我们考虑用单调队列优化. 原题中说她只 ...

  5. 洛谷—— P1725 琪露诺

    https://www.luogu.org/problem/show?pid=1725 题目描述 在幻想乡,琪露诺是以笨蛋闻名的冰之妖精.某一天,琪露诺又在玩速冻青蛙,就是用冰把青蛙瞬间冻起来.但是这 ...

  6. Luogu【P1725】琪露诺(单调队列,DP)

    本文是笔者第二篇解题报告.从现在开始,会将练的一些题发到博客上并归类到"解题报告"标签中. 琪露诺是这样一道题 这道题可以用纯DP做,但是据说会超时.(为什么?看起来过河这题比它数 ...

  7. [洛谷P3693]琪露诺的冰雪小屋

    题目大意:琪露诺的冰雪小屋,我做的第一道大模拟题. 题解:模拟... 卡点:无数小错误,要是没有写一点调一点,那大概是永远调不出来了... C++ Code: #include <cstdio& ...

  8. luoguP1725 琪露诺 单调队列

    DP 方程:$f[i]=max(f[j])+v[i]$ 转移范围:$i-r<=j<=i-l$ 由此我们得知,每次只有 $[i-r,i-l]$ 部分的 $f$ 值对新更新的答案会有贡献. 故 ...

  9. P1725 琪露诺

    P1725 琪露诺 单调队列优化dp 对于不是常数转移的dp转移,我们都可以考虑单调队列转移 然而我们要把数组开大 #include<cstdio> #include<algorit ...

随机推荐

  1. 【freertos】013-任务通知及其实现细节

    前言 参考: https://www.freertos.org/RTOS-task-notifications.html 原文:https://www.cnblogs.com/lizhuming/p/ ...

  2. pytest-fixture执行顺序

    作用域-scope 作用域越大,越先执行,session>package>module>class>function. 是否自动调用fixture 自动调用(autouse=T ...

  3. GitHub Pages 站点建设

    1.简介 GitHub Pages 是通过 GitHub 托管和发布的公共网页,将纯文本转换为静态博客网站. 您可以使用 GitHub Pages 来展示一些开源项目.博客甚或分享您的简历,有内存限制 ...

  4. 基于bert_bilstm_crf的命名实体

    前言 本文将介绍基于pytorch的bert_bilstm_crf进行命名实体识别,涵盖多个数据集.命名实体识别指的是从文本中提取出想要的实体,本文使用的标注方式是BIOES,例如,对于文本虞兔良先生 ...

  5. docker 容器terminal失败

    关键一句话:docker 容器的teminal失败,一定是等待资源导致的,不管是pid资源,还是内存资源.本文主要讲因为内存资源导致进程D状态,然后导致teminal容器失败. 目前在集群中,cpu占 ...

  6. Python小白自学笔记:英语不好,变量怎么命名

    变量其实很简单,不过在使用过程中会遇到一些棘手的问题. 比如一个变量我之前已经用过了,现在我要定义一个类似的变量,该怎么办? 还有,很多小伙伴其实知道变量应该遵守什么规范,应该代表什么数据,但是大学英 ...

  7. redis淘汰策略和过期策略

    淘汰策略 https://blog.csdn.net/qq_55961709/article/details/124568269 LRU算法和LFU算法的区别: LRU:最近最少使用,淘汰时间长没有使 ...

  8. 【NOI P模拟赛】奶油蛋糕塔(状压 DP)

    题面 数据范围 1 ≤ n ≤ 5 × 1 0 5 1\leq n\leq5\times10^5 1≤n≤5×105 . 题解 n ≤ 20 n\leq 20 n≤20 的状压应该都会吧,状态记录已经 ...

  9. 【NOI P模拟赛】(要素过多的标题)(容斥原理)

    题面 0 题目背景 [ 数   据   删   除 ] _{^{[数\,据\,删\,除]}} [数据删除]​ 1 题目描述 在执行任务时,收集到了 n n n 份能源,其中第 i i i 份的能量值是 ...

  10. 【Java】学习路径34-文件IO练习题

    练习题: 1.检测某目录(scr目录为例)下java源程序文件的数量. 参考思路: 首先获取到scr目录,然后使用list()获取所有名字,再使用String类下的endsWith方法检查即可. 参考 ...