《数据结构》01-复杂度1 最大子列和问题

int MaxSubseqSum(int a[],long K);
int Max3(int a,int b,int c);
int DivideConquer(int a[],long K);
int main(int argc,char* argv[])
{
    long K;
    int i;
    scanf("%ld",&K);
    int a[K];
    for(i=0;i<K;i++){
        scanf("%d",&a[i]);
    }
    printf("%d",MaxSubseqSum(a,K));
    return 0;
}
int MaxSubseqSum(int a[],long K)
{
    return DivideConquer(a,K);
}
int Max3(int a,int b,int c)
{
    int max=a;
    max=a>b?a:b;
    max=max>c?max:c;
    return max;
}
int DivideConquer(int a[],long K)
{
    int MaxLeftSum=0,MaxRightSum=0,MaxBorderSum=0;
    int MaxLeftBorderSum=0,MaxRightBorderSum=0;
    int ScanSum=0;
    long center=K/2;
    int i;
    for(i=center-1,ScanSum=0;i>=0;i--){
        ScanSum+=a[i];
        if(ScanSum>MaxLeftBorderSum) MaxLeftBorderSum=ScanSum;
    }
    for(i=center,ScanSum=0;i<=K-1;i++){
        ScanSum+=a[i];
        if(ScanSum>MaxRightBorderSum) MaxRightBorderSum=ScanSum;
    }
    MaxBorderSum=MaxLeftBorderSum+MaxRightBorderSum;
    //递归基础
    if(K==1){
        return a[0]>0?a[0]:0;
    }

    //递归调用
    MaxLeftSum=MaxSubseqSum(a,center);
    MaxRightSum=MaxSubseqSum(a+center,K-center);
    return Max3(MaxLeftSum,MaxRightSum,MaxBorderSum);
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值