dp 优化 F2. Pictures with Kittens (hard version)
dp的优化可能是自己的弱项吧
F1中n*n*n的复杂度强行过去了
F2就无能为力了;
状态转移
dp[ i ] [ j ] 第一个i存的是位置 1-n; j是放入数字的个数 然后F1就暴力过去了
#include<bits/stdc++.h>
#define int long long
using namespace std;
const int maxn=+;
int dp[maxn][maxn];
int a[maxn];
int32_t main()
{
int n,k,x; cin>>n>>k>>x;
for(int i=;i<=n;i++) cin>>a[i];
dp[][]=;
for(int i=;i<=n;i++)
{
//cout<<" "<<i<<endl;
//cout<<" "<<i-k+1<<endl;
for(int j=i-k;j<i;j++)
{
if(j<) continue;
for(int q=(i-)/k;q<x;q++)
{
if(dp[j][q]||i<=k) dp[i][q+]=max(dp[i][q+],dp[j][q]+a[i]);
}
} }
int maxn=;
for(int i=n;i>=n-k+;i--)
{
maxn=max(dp[i][x],maxn);
}
if(maxn) cout<<maxn<<endl;
else cout<<-<<endl;
}
暴力的F1
然后F2 gg了
看了别人的代码 大致有几种写法
双端队列优化 deque<pair<int,int> > de[maxn];
写的不难懂点 de[ ] [ ] [ ] 大致就是这样存的 de[ ] 这个表示的是 存的数字个数 第二个括号存的是 第i个位置j个数的最大值; 第三个括号存的是 位置
第i个位置是由 前[ i-k,i-1 ]位置的地方转移过来的;
从 de[j] 到 de[j+1] 必须确定 de[j+1] 已经转移了 所以第二层转移就是 j=x-1; j>=0;j--;
#include<bits/stdc++.h>
#define int long long
using namespace std;
const int maxn=5e3+;
int a[maxn];
deque<pair<int,int> > de[maxn];
int32_t main()
{
//priority_queue(int,vector<int>,greater<int>) qu;
int n,k,x; cin>>n>>k>>x;
for(int i=;i<=n;i++) cin>>a[i];
int ans=-;
de[].push_back({,}) ; // first cun zhi second pos;
for(int i=;i<=n;i++)
{
for(int j=x-;j>=;j--)
{
while(!de[j].empty() && de[j].front().second<i-k ) de[j].pop_front(); // i-k
if(de[j].empty()) continue;
int val=de[j].front().first+a[i]; // jia shang zhe ge shu
while(!de[j+].empty() && de[j+].back().first <=val ) de[j+].pop_back();
de[j+].push_back({val,i}); // di i ge wei zhi j+1 ge shu he zui da
if(j+==x&&i+k>n)
{
ans=max(val,ans);
}
}
}
cout<<ans<<endl; }
看的懂的代码
dp 优化 F2. Pictures with Kittens (hard version)的更多相关文章
- Codeforces 1077 F2 - Pictures with Kittens (hard version)
F2 - Pictures with Kittens (hard version) 思路: 单调队列优化dp 代码: #pragma GCC optimize(2) #pragma GCC optim ...
- Codeforces 1077F2 Pictures with Kittens (hard version)(DP+单调队列优化)
题目链接:Pictures with Kittens (hard version) 题意:给定n长度的数字序列ai,求从中选出x个满足任意k长度区间都至少有一个被选到的最大和. 题解:数据量5000, ...
- Codeforces 1077F1 Pictures with Kittens (easy version)(DP)
题目链接:Pictures with Kittens (easy version) 题意:给定n长度的数字序列ai,求从中选出x个满足任意k长度区间都至少有一个被选到的最大和. 题解:$dp[i][j ...
- Codeforces Round #521 (Div. 3) F1. Pictures with Kittens (easy version)
F1. Pictures with Kittens (easy version) 题目链接:https://codeforces.com/contest/1077/problem/F1 题意: 给出n ...
- NOIP2015 子串 (DP+优化)
子串 (substring.cpp/c/pas) [问题描述] 有两个仅包含小写英文字母的字符串 A 和 B.现在要从字符串 A 中取出 k 个 互不重 叠 的非空子串,然后把这 k 个子串按照其在字 ...
- LCIS tyvj1071 DP优化
思路: f[i][j]表示n1串第i个与n2串第j个且以j结尾的LCIS长度. 很好想的一个DP. 然后难点是优化.这道题也算是用到了DP优化的一个经典类型吧. 可以这样说,这类DP优化的起因是发现重 ...
- 取数字(dp优化)
取数字(dp优化) 给定n个整数\(a_i\),你需要从中选取若干个数,使得它们的和是m的倍数.问有多少种方案.有多个询问,每次询问一个的m对应的答案. \(1\le n\le 200000,1\le ...
- dp优化1——sgq(单调队列)
该文是对dp的提高(并非是dp入门,dp入门者请先参考其他文章) 有时候dp的复杂度也有点大...会被卡. 这几次blog大多数会讲dp优化. 回归noip2017PJT4.(题目可以自己去百度).就 ...
- loj6171/bzoj4899 记忆的轮廊(期望dp+优化)
题目: https://loj.ac/problem/6171 分析: 设dp[i][j]表示从第i个点出发(正确节点),还可以有j个存档点(在i点使用一个存档机会),走到终点n的期望步数 那么 a[ ...
随机推荐
- 【Junit_Ant】使用Eclipse自带的Junit和Ant,生成测试报告
使用Eclipse自带的Junit和Ant,生成测试报告 1.点击要测试的工程,右击,选择Export 2.在弹出的页面里,点击General,选择Ant Buildfiles,点击Next 3.在下 ...
- 求1+2+……+n的和
题目描述 求1+2+3+...+n,要求不能使用乘除法.for.while.if.else.switch.case等关键字及条件判断语句(A?B:C). class Solution { public ...
- U深度U盘启动盘制作教程
① 下载u深度u盘启动盘制作工具 ② 一个能够正常使用的u盘(容量大小建议在4g以上) 第一步:安装u深度u盘启动盘制作工具 双击打开已下载好的安装包,点击窗口中立即安装即可: 等待安装完成后,可以点 ...
- Java正则表达式校验
package com.study.string; import java.util.regex.Matcher; import java.util.regex.Pattern; /** * 正则表达 ...
- 回溯算法 LEETCODE别人的小结 一八皇后问题
回溯算法实际上是一个类似枚举的搜索尝试过程,主要是在搜索尝试中寻找问题的解,当发现已不满足求解条件时,就回溯返回,尝试别的路径. 回溯法是一种选优搜索法,按选优条件向前搜索,以达到目的.但是当探索到某 ...
- oo作业总结(一)
概述 经历了三次oo作业的洗礼,让我对java语言的强大以及面向对象编程有了初步的理解(当然,我是小白).本文接下来就将对自己这三次作业的代码进行分析以及分享自己的心路历程. 基础知识点考核 针对前三 ...
- 1014 2018 使用FLAG counter
AmazingCounters.com 不能用了,服务器访问不了了,之前的博客浏览量也看不到了,1014号换了个新的--FLAG counter,就是博客右边那个.
- 顺便谈谈对于Java程序猿学习当中各个阶段的建议
引言 其实本来真的没打算写这篇文章,主要是LZ得记忆力不是很好,不像一些记忆力强的人,面试完以后,几乎能把自己和面试官的对话都给记下来.LZ自己当初面试完以后,除了记住一些聊过的知识点以外,具体的内容 ...
- spin lock自旋锁 双链表操作(多线程安全)(Ring0)
通过spin lock自旋锁 ,为每个链表都定义并初始化一个锁,在需要向该链表插入或移除节点时不使用前面介绍的普通函数,而是使用如下方法: ExInterlockedInsertHeadList(&a ...
- L259
Few things can feel as crushing as being rejected by someone who you're either dating or romanticall ...