牛客-https://www.nowcoder.com/acm/contest/96/H
链接:https://www.nowcoder.com/acm/contest/96/H
来源:牛客网
题目描述
他想选总共2k道题来做,并且期望他能获得的分数尽可能的大,他准备选2个不连续的长度为k的区间,
即[L,L+1,L+2,....,L+k-1],[R,R+1,R+2,...,R+k-1](R >= L+k)。
输入描述:
第一行一个整数T(T<=10),代表有T组数据
接下来一行两个整数n,k,(1<=n<=200,000),(1<=k,2k <= n)
接下来一行n个整数a1,a2,...,an,(-100,000<=ai<=100,000)
输出描述:
输出一个整数,qwb能获得的最大分数
输入例子:
2
6 3
1 1 1 1 1 1
8 2
-1 0 2 -1 -1 2 3 -1
输出例子:
6
7
-->
输入
2
6 3
1 1 1 1 1 1
8 2
-1 0 2 -1 -1 2 3 -1
输出
6
7 dp预处理出来f1,f2数组,f1[i]表示a[1..i]中长度为k的最大值,f2[i]表示a[i..n]中长度为k的最大值。然后枚举中间点得到最大值。
#include<iostream>
#include<cstdio>
#include<cstring>
#include<queue>
#include<cmath>
#include<algorithm>
#include<map>
#include<set>
#include<vector>
#include<functional>
using namespace std;
#define LL long long
#define pii pair<long long ,int>
#define mp make_pair
#define inf 0x3f3f3f3f
#define linf 0xffffffffff
LL a[],pre[],f1[],f2[];
int main()
{
//cout<<linf<<endl;
int n,m,i,j,k,t;
cin>>t;
while(t--){
cin>>n>>k;
for(i=;i<=n;++i) scanf("%lld",a+i),pre[i]=pre[i-]+a[i],f1[i]=f2[i]=-linf;
// memset(f1,-inf,sizeof(f1));
// memset(f2,-inf,sizeof(f2));
for(i=k;i<=n;++i){
f1[i]=max(f1[i-],pre[i]-pre[i-k]);
}
for(i=n-k+;i>=;--i){
f2[i]=max(f2[i+],pre[i+k-]-pre[i-]);
}
LL ans=-linf;
for(i=k;i<n-k+;++i){
ans=max(ans,f1[i]+f2[i+]);
}
cout<<ans<<endl;
}
return ;
}
牛客-https://www.nowcoder.com/acm/contest/96/H的更多相关文章
- 牛客练习赛51 C 勾股定理https://ac.nowcoder.com/acm/contest/1083/C
		题目描述 给出直角三角形其中一条边的长度n,你的任务是构造剩下的两条边,使这三条边能构成一个直角三角形. 输入描述: 一个整数n. 输出描述: 另外两条边b,c.答案不唯一,只要输出任意一组即为合理, ... 
- 牛客练习赛51 B  子串查询    https://ac.nowcoder.com/acm/contest/1083/B
		题目描述 给出一个长度为n的字符串s和q个查询.对于每一个查询,会输入一个字符串t,你需要判断这个字符串t是不是s的子串.子串的定义就是存在任意下标a<b<c<d<e,那么”s ... 
- 2019牛客暑期多校训练营(第三场)H题目
		题意:给你一个N×N的矩阵,求最大的子矩阵 满足子矩阵中最大值和最小值之差小于等于m. 思路:这题是求满足条件的最大子矩阵,毫无疑问要遍历所有矩阵,并判断矩阵是某满足这个条件,那么我们大致只要解决两个 ... 
- 牛客网暑期ACM多校训练营(第三场)H  Diff-prime Pairs (贡献)
		牛客网暑期ACM多校训练营(第三场)H Diff-prime Pairs (贡献) 链接:https://ac.nowcoder.com/acm/contest/141/H来源:牛客网 Eddy ha ... 
- 2018牛客网暑假ACM多校训练赛(第十场)H Rikka with Ants 类欧几里德算法
		原文链接https://www.cnblogs.com/zhouzhendong/p/NowCoder-2018-Summer-Round10-H.html 题目传送门 - https://www.n ... 
- 2018牛客网暑假ACM多校训练赛(第八场)H Playing games 博弈 FWT
		原文链接https://www.cnblogs.com/zhouzhendong/p/NowCoder-2018-Summer-Round8-H.html 题目传送门 - https://www.no ... 
- 2018牛客网暑假ACM多校训练赛(第五场)H subseq 树状数组
		原文链接https://www.cnblogs.com/zhouzhendong/p/NowCoder-2018-Summer-Round5-H.html 题目传送门 - https://www.no ... 
- 2018牛客网暑期ACM多校训练营(第三场) H - Diff-prime Pairs - [欧拉筛法求素数]
		题目链接:https://www.nowcoder.com/acm/contest/141/H 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ 262144K,其他语言524288K ... 
- 牛客小白月赛13  	小A的柱状图(单调栈)
		链接:https://ac.nowcoder.com/acm/contest/549/H来源:牛客网 题目描述 柱状图是有一些宽度相等的矩形下端对齐以后横向排列的图形,但是小A的柱状图却不是一个规范的 ... 
随机推荐
- vim文本编辑操作
			文本选择操作 为了方便地选取文本块,Vim编辑器引入了可视模式(Visual Mode).要选取一段文本块,操作步骤如下: ▶ 将光标移动到要复制文本块的开始处.要注意的是 ... 
- Mybatis中的#与$的区别
			一.对比场景 场景:数据库分表时,需要将分表的表序号传入的sql中. SpringBoot中使用注解如下: @Insert("insert into collect_#{tblNum}(id ... 
- 『NiFi 学习之路』简介
			『NiFi 学习之路』简介 『NiFi 学习之路』入门 -- 下载.安装与简单使用 『NiFi 学习之路』资源 -- 资料汇总 『NiFi 学习之路』把握 -- 架构及主要组件 『NiFi 学习之路』 ... 
- ElasticSearch的x-pack配置查询
			ElasticSearch在安装完x-pack后, 存在客户端通过Transport访问ES出现异常:java.lang.IllegalArgumentException: Unknown Named ... 
- Python学习笔记之Python的多重继承和MixIn
			多重继承 继承是面向对象编程的一个重要的方式,因为通过继承,子类就可以扩展父类的功能. 回忆一下Animal类层次的设计,假设我们要实现以下4种动物: Dog - 狗狗: Bat - 蝙蝠: Parr ... 
- Windows打开软件老是弹出无法验证发布者
			使用组策略管理器 gpedit.msc 用户配置-管理模板-Windows组件-附件管理器-中等风险文件类型的包含列表 .exe;.cmd;.bat;.js即可 
- 照着官网来安装openstack pike之keystone安装
			openstack基础环境安装完成后,现在开启安装keystone服务(在控制节点上执行下面所有操作) 1.为keystone创建数据库 mysql -u root -p MariaDB [(none ... 
- Codeforces 235C. Cyclical Quest
			传送门 写的时候挺蛋疼的. 刚开始的时候思路没跑偏,无非就是建个SAM然后把串开两倍然后在SAM上跑完后统计贡献.但是卡在第二个样例上就是没考虑相同的情况. 然后开始乱搞,发现会出现相同串的只有可能是 ... 
- Elasticsearch+Kibana+Logstash安装
			安装环境: [root@node- src]# cat /etc/redhat-release CentOS Linux release (Core) 安装之前关闭防火墙 firewalld 和 se ... 
- vscode调试pomelo和pomelo使用vscode调试
			使用vscode 通过端口remote attach进行调试 pomelo. 0. 网上好多调试pomelo的都是webstorm.或者vscode调试node的教程.但没找到vscode调试pome ... 
