在线规划算法解决最大子数列和问题

在线规划算法作为我所接触的第一个高级算法,其效率高,核心价值在于"在有限的时间内生成足够好的决策"而非追求全局最优,具有动态适应性。

代码实现


#include <iostream>
using namespace std;
            
int main() {
    std::ios::sync_with_stdio(false);
    int n, begin = 0, end = 0, temp_begin = 0;
    long long sum = 0;
    int temp = 0;
    cin >> n;
    int *p = new int[n]; 
    for(int i = 0; i < n; i++) {
        cin >> p[i];
    }
    long long max = -1;
    for(int i = 0; i < n; i++) {
        sum += p[i];
        if(sum > max) {
            end = i;
            max = sum;
            begin = temp_begin;
        }
        if(sum < 0) {
            sum = 0;
            temp_begin = i + 1;// 重置时设置下一个位置为起点
        }
    }
        if(max < 0) {
            max = 0;
            begin = 0;
            end = n-1;
        }
        cout << max << " " << p[begin] << " " << p[end];
        delete[] p;
        return 0;
}