数学考试

数学考试

https://ac.nowcoder.com/acm/problem/15553

//数学考试
//算法核心:前缀和 
//本质:前缀和
//long long 被ex到了 
#include <bits/stdc++.h>
using namespace std;

typedef long long ll;
int n;
ll arr[200005];
int main()
{ 
    int i,j,k,t;
    cin>>t;
    while(t--)
    {
    memset(arr,0,sizeof(arr));//每组开始都要清数组 
    cin>>n>>k;
    for(i=1;i<=n;i++)    
    {
    cin>>arr[i];
    arr[i]+=arr[i-1];//边输入边前缀和处理 
    }
    ll maxn1=-1e18,maxn2=-1e18;//maxn1为第一个区间最大值,maxn2为第一个区间最大加上第二个区间最大值 
    for(i=k;i<=n-k;i++)
    {
        maxn1=max(maxn1,arr[i]-arr[i-k]);//不断更新第一个区间最大值
        maxn2=max(maxn2,maxn1+arr[i+k]-arr[i]);//不断更新俩区间之和最大值 
    }
    cout<<maxn2<<endl; 
    }
}
全部评论

相关推荐

05-12 17:28
已编辑
门头沟学院 硬件开发
ldf李鑫:不说公司名祝你以后天天遇到这样的公司
点赞 评论 收藏
分享
求面试求offer啊啊啊啊:1600一个月?
点赞 评论 收藏
分享
评论
1
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务