-3

我正在做一个 spoj 的问题,我试图这样做,但我总是得到 TLE(时间限制已过期)问题是酒店。这是我的代码,请你告诉我优化它的方法。

#include<stdio.h>

int main()
{
    unsigned long long int a,b,i;
    scanf("%llu %llu",&a,&b);
    unsigned long long int arr[a];
    for(i=0;i<a;i++)
    {
        scanf("%llu",&arr[i]);
    }


        unsigned long long int d;
        unsigned long long int k,z=0;
    for(i=0;i<a;i++)
    {
        d = arr[i];
        for(k=i+1;k<a+1;k++)
        {
            if (d<b)
            {
                if(z<d)
                z = d;
            }
            else
            if(d==b)
            {
                z = d;
                break;
            }
            else
            break;
            d = d + arr[k];
        }
        if(d==b)
        break;
    }
    printf("%llu",z);
    return 0;
}

在这种情况下,如果输入 5 12 ,这五个是 2 1 3 4 5 使 12 然后我这样做:首先我将 12 与 2 进行比较,然后是 2+1 ,然后是 2+1+3 等等5 它将 12 与 1 、 1+3 、 1+3+4 .. 进行比较,以这种方式,当我发现等于 12 时,我只采用连续的并中断,否则它会一直持续到最后。

希特什

4

1 回答 1

3

没有必要像你在解释中所说的那样重新启动after it goes to 5 it compares 12 to 1 , 1+3 , 1+3+4 .. and in this way。仔细查看您的方法,您正在一次又一次地重新计算子数组的总和。例如 - 你1+3+4在做的时候已经计算了子数组的总和2+1+3+4。因此仍有一定的优化空间。

在说出确切的解决方案之前,我希望您先尝试一下。另外一个提示参考以下问题Find subarray with given sum

编辑:为将来的目的共享完整的解决方案。

#include<stdio.h>

/* Returns the maximum possible sum less than or equal to the gieven sum */
int subArraySum(int arr[], int n, int sum)
{
    /* Initialize curr_sum as value of first element
     and starting point as 0 */
    int curr_sum = arr[0], max_sum = 0, start = 0, i;

    /* Add elements one by one to curr_sum and if the curr_sum exceeds the
     sum, then remove starting element */
    for (i = 1; i <= n; i++)
    {
        // If curr_sum exceeds the sum, then remove the starting elements
        while (curr_sum > sum && start < i-1)
        {
            curr_sum = curr_sum - arr[start];
            start++;
        }

        //keep track of the maximum sum so far.
        if (max_sum < curr_sum)
            max_sum = curr_sum;

        curr_sum = curr_sum + arr[i];
    }

    return max_sum;
}

// 测试上述功能的驱动程序

int main()
{
    int arr[] = {7, 3, 5, 6};
    int n = sizeof(arr)/sizeof(arr[0]);
    int sum = 9;
    printf("Max Sum = %d\n", subArraySum(arr, n, sum));
    return 0;
}
于 2012-06-03T06:07:44.407 回答