算法导论4.1-2 最大子数组问题的暴力解

题目

对最大子数组问题,编写暴力求解方法的伪代码,其运行时间应该是θ(n^2)

题解

θ(n^2)的方法是通过保存二维数组的上一个计算结果,即i..j的和,来计算i..j+1的和。

c++代码写一遍。

#include <cstdio>
#include <cstring>
#include <climits>

struct Sub {
    int low;
    int high;
    int sum;
};

Sub FindMaximumSubarray(const int array[], int count) {
    int sum[count][count];
    Sub maxSub = { 0, 0, -INT_MIN};
    for (int i = 0; i < count; ++i) {
        for (int j = i; j < count; ++j) {
            if (i != j) {
                sum[i][j] = sum[i][j-1] + array[j];
            } else {
                sum[i][j] = array[j];
            }
            if (sum[i][j] > maxSub.sum) {
                maxSub = { i, j, sum[i][j] };
            }
        }
    }
    return  maxSub;
}

int main() {
    int arr[] = { 13, -3, -25, 20, -3, -16, -23, 18, 20, -7, 12, -5, -22, 15, -4, 7 };
    Sub ans = FindMaximumSubarray(arr, sizeof(arr)/sizeof(arr[0]));
    printf("low = %d, high = %d, sum = %d", ans.low, ans.high, ans.sum);
    return 0;
}

附上github代码地址: https://github.com/FengHaiTongLuo/Introduction-to-Algorithms-Prac/blob/main/prac_4.1-2.cpp


通过微信公众号”风海铜锣技术君“的菜单可以加我入面试交流的”程序员卷卷群“。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值