从 n 个数中取连续的 m 个数, 使其和最大

2018-07-06  本文已影响0人  风骚的风

穷举法的时间复杂度为 O(nm - m^2), 略去实现.

以下实现的时间复杂度为 O(n - m), 空间复杂度为 O(1).

public class Test {

    public static void main(String[] args) {
        int[] numberArr = {1, 2, 4, 6, 2, 1, 0, -1, 8, 10, 0};
        int range = 4;
        int result = find(numberArr, range);
        System.out.println("满足条件的子集的起始索引为: " + result);
    }

    public static int find(int[] numberArr, int range) {
        int target = 0, i = 0, j = range;
        int isum = 0, jsum = 0;

        for (; j < numberArr.length; i++, j++) {
            isum += numberArr[i];
            jsum += numberArr[j];
            if (isum < jsum) {
                target = j + 1 - range;
                isum = 0;
                jsum = 0;
            }
        }

        return target;
    }
}
上一篇 下一篇

猜你喜欢

热点阅读