当前位置: 首页 > 知识库问答 >
问题:

子数组中的最大和

柴瀚昂
2023-03-14

给出了一个由N个整数组成的数组。
数组的最大和是该数组的非空连续子数组的元素的最大和。
例如,数组[1,-2,3,-2,5]的最大和是6,因为子数组[3,-2,5]的和是6,并且不可能实现更大的子数组和。
现在,您只能从给定数组中删除一个以上的元素。这样做可以得到的结果数组的最大可能最大和是多少?

我正在用我自己的测试用例测试我的代码。我在Dev-C++上得到了正确的输出。但是当我在网上测试我的代码时,我得到了错误的答案。我无法找出问题出在哪里。

#include <stdio.h>
#include <limits.h>
#include <stdlib.h>
struct result{
    long long int start;
    long long int end;
    long long int sum;
}res;
long long int find_max(long long int a[],long long int n)
{
    long long int max=LLONG_MIN;
    long long int i;
    for(i=0;i<n;++i)
    {
        if(a[i]>max)
            max=a[i];
    }
    return max;
}
long long int max_sub(long long int a[],long long int n)
{
    long long int i;
    long long int min,sum1=0;
    struct result max,max_curr,*maxsub;
    maxsub=calloc(sizeof(res),n);
    max.sum=LLONG_MIN;
    max_curr=max;
    for(i=0;i<n;++i)
    {
        if(max_curr.sum<0)
        {
            max_curr.sum=a[i];
            max_curr.start=i;
            max_curr.end=i;
        }
        else
        {
            max_curr.sum+=a[i];
            max_curr.end=i;
        }
        if(max_curr.sum>max.sum)
        {
            max=max_curr;
        }
        maxsub[i]=max;
    }
    min=0;
    for(i=maxsub[n-1].start;i<=maxsub[n-1].end;++i)
    {
        if(a[i]<0)
        {
            if(min==0 || a[i]<min)
                min=a[i];
        }
    }
    sum1=maxsub[n-1].sum-min;
    return sum1;
}
int main()
{
    int t;
    scanf("%d",&t);
    while(t--){
        long long int n,i;
        scanf("%lld",&n);
        long long int a[n];
        for(i=0;i<n;++i)
            scanf("%lld",&a[i]);
        long long int sum=0;
        sum=find_max(a,n);
        if(sum<=0)
        {
            printf("%lld\n",sum);
        }
        else
        {
            sum=max_sub(a,n);
            printf("%lld\n",sum);
        }

    }
    return 0;
}

共有1个答案

蓬弘
2023-03-14

请关闭此线程。OP试图在一个正在进行的在线比赛中作弊,通过在这里发布问题。

 类似资料:
  • 我试图在一个数组中找到具有最大和的邻接子数组。所以,对于数组 {5,15,-30,10,-5,40,10}

  • 很抱歉发了这么长的帖子,但我不明白我做错了什么。感谢您事先的帮助! 这里是当前面提到的列表作为输入给出时的输出,我已经经历并查看了每一个步骤,列表中的每一个消除在我看来都是合乎逻辑的,我不知道一个人怎么会以结束和105结束。如果有人能帮我理解,我会非常感激的!

  • 最大乘积子数组给定一个数组包含正整数和负整数,求最大乘积的子数组。例子: 但不能破题找到子数组。

  • NowCoder 题目描述 {6, -3, -2, 7, -15, 1, 2, 2},连续子数组的最大和为 8(从第 0 个开始,到第 3 个为止)。 解题思路 // java public int FindGreatestSumOfSubArray(int[] nums) { if (nums == null || nums.length == 0) return 0;

  • 给定一个数组,编写一个程序以在大小的所有子数组中找到最大 gcd 我的代码: 它是O(N^2),还能再优化吗?

  • 我想从数组的一部分找到最大值和最小值。我知道我可以通过复制数组将所需的数组部分复制到另一个数组中,但只是想知道是否可以不复制数组,因为我必须为不同的子数组进行循环 例如: 现在我想从1到4找到子数组的最小/最大值(如果可能,不复制子数组)