在斯波杰酒店获得TLE

getting TLE in Spoj-Hotels

本文关键字:TLE 酒店      更新时间:2023-10-16

我收到来自spoj的酒店超过时间限制。

这是我的代码:

int main()
{
    long long n,m;
    scanf("%lld",&n);
    scanf("%lld",&m);
    long long a[300005],dp[300005];
    for(int i=0;i<n;i++) scanf("%lld",&a[i])
    for(int i=1;i<n;i++) a[i]+=a[i-1];
    for(int i=n-1;i>=0;i--)
    {
        if(a[i]<m){ 
            dp[0] = a[i];
            break; 
        }
    }
    for(int i=1;i<n;i++)
    {
        long long x = a[i-1];
        for(int j=i;j<n;j++)
        {
            a[j]-=x;
        }
        for(int j=n-1;j>=i;j--)
        {
            if(a[j]<=m){ 
            dp[i] = a[j];
            break; 
            }
        }
    }
    long long max_=0;
    for(int i=0;i<n;i++)
    {
        max_ = max(max_,dp[i]);
    }
    printf("%lldn",max_);
    return 0;
}

解释:

首先,我通过与以前的值相加来计算数组"a"中的所有值。然后,计算出dp数组中小于等于"m"的最大值。然后,我开始从前面的减去数组中每个元素的当前值,并将值存储在dp数组中。所以,dp数组的最大值会给我答案。

例如:n=5,m=12;

2 1 3 4 5

我的数组"a":2 3 6 10 15

然后在第二遍之后:2 1 4 8 13

然后在第三遍之后:2 1 3 7 12

以下是有效的代码:Ideone

这个问题的复杂性为O(n)。

#include <iostream>
using namespace std;
int a[300013];
int main(){
    int n,m;
    scanf("%d%d",&n,&m);
    for(int i=0; i<n; i++) scanf("%d",&a[i]);
    long long sumNow = 0;
    long long maxAns = 0;
    int left=0,right=-1;
    while(right!= n-1){
        right++;
        sumNow+=a[right];
        while(sumNow>m){
            sumNow-=a[left];
            left++;
        }
        maxAns = max(maxAns,sumNow);
    }
    printf("%lld", maxAns);
    return 0;
}