J - Minimal Subarray Length UVALive - 6609
1.比赛时没想到用数组存和。。。就遇到了许多尴尬的情况。
如示例:
6 100
10 10 60 80 90 10
9 10
1 1 2 2 2 2 2 -2 4
已经满足条件后,需要向前扫,保留减掉后仍然满足>=x的情况。
比赛时写的代码倒是想到了这个情况,但是还是没有覆盖到所有情况,就如样例2.
int nowlen=0, sum=0,ans=inf;
int ave=0;
for(i=0; i<n; i++)
{
if(sum<=0&&sum<x)
{
sum=0;
nowlen = 0;
ave=i;
}
sum+=a[i];
nowlen++;
if(sum>=x)
{
ans=min(ans,nowlen);
for(int j=ave; j<i; j++)
{
if(sum-a[j]>=x)
{
nowlen--;
sum=sum-a[j];
}
else break;
}
ans=min(ans,nowlen);
sum=a[i];
ave=i;
nowlen=1;
if(sum>=x) ans=min(ans,nowlen);
}
}
Accepted code
#include <iostream>
#include <cstdio>
#include <cstring>
#include <cstdlib>
#include <queue>
#include <algorithm>
#define inf 0x3f3f3f
using namespace std;
int main()
{
int t;
int i, j;
int a[512345],b[512345],c[512345];
cin>>t;
while(t--)
{
int n,x;
int ans = inf;
cin>>n>>x;
memset(c,1,sizeof(c));
for(i=0;i<n;i++)
{
scanf("%d",&a[i]);
b[i]=a[i];
}
for(i=0;i<n;i++)
{
if(b[i-1]<=0)
{
c[i]=1;
b[i]=a[i];
}
else
{
b[i]=b[i-1] + a[i];
c[i]=c[i-1] +1;
}
if(b[i]>=x)
{
ans=min(ans,c[i]);
for(int j=i;j>=0;j--)
{
if(b[i]-b[j]>=x) {ans=min(ans,i-j);break;}
}
}
}
if(ans!=inf) cout<<ans<<endl;
else cout<<"-1"<<endl;
}
return 0;
}