CSP-J复赛复习专栏 - 03kadane算法

kadane's算法

1.1一维kadane's算法

题目:最大利润区间(最大连续子序列和)

背景:

小明是一个股票交易员。他有一份记录了某只股票在连续N天中的每日利润(可能为正,也可能为负)。小明想要知道在这N天中,他如果选择一个连续的交易区间,最多能获得多少利润。

问题:

给定一个长度为N的整数数组,表示股票在N天中的每日利润。请计算可以获得的最大连续利润。如果不可能获得正利润,则输出0。

输入格式:

第一行包含一个整数N(1 ≤ N ≤ 100000),表示天数。

第二行包含N个整数,每个整数的绝对值不超过10000,表示每天的利润。

输出格式:

输出一个整数,表示最大连续利润。如果不可能获得正利润,输出0。

样例输入:

8

-2 -3 4 -1 -2 1 5 -3

样例输出:

7

解释:

最大利润区间为第3天到第7天,总利润为4 + (-1) + (-2) + 1 + 5 = 7。

提示:

考虑使用Kadane算法来解决这个问题。

注意处理全是负数的情况。
(1)题目解析

cpp 复制代码
#include <iostream>
#include <vector>
#include <algorithm>

typedef long long ll;

using namespace std;

ll maxProfit(const vector<ll>& profits) {
    ll max_so_far = 0;  // 初始化为0,因为如果全是负数,我们选择不交易
    ll max_ending_here = 0;
    bool all_negative = true;

    for (ll profit : profits) {
        if (profit > 0) all_negative = false;
        max_ending_here = max(profit, max_ending_here + profit);
        max_so_far = max(max_so_far, max_ending_here);
    }

    // 如果全是负数,返回0
    return all_negative ? 0 : max_so_far;
}

int main() {
    ll N;
    cin >> N;

    vector<ll> profits(N);
    for (ll i = 0; i < N; ++i) {
        cin >> profits[i];
    }

    cout << maxProfit(profits) << endl;

    return 0;
}
相关推荐
88号技师4 小时前
2024年12月一区SCI-加权平均优化算法Weighted average algorithm-附Matlab免费代码
人工智能·算法·matlab·优化算法
IT猿手4 小时前
多目标应用(一):多目标麋鹿优化算法(MOEHO)求解10个工程应用,提供完整MATLAB代码
开发语言·人工智能·算法·机器学习·matlab
88号技师4 小时前
几款性能优秀的差分进化算法DE(SaDE、JADE,SHADE,LSHADE、LSHADE_SPACMA、LSHADE_EpSin)-附Matlab免费代码
开发语言·人工智能·算法·matlab·优化算法
我要学编程(ಥ_ಥ)5 小时前
一文详解“二叉树中的深搜“在算法中的应用
java·数据结构·算法·leetcode·深度优先
埃菲尔铁塔_CV算法5 小时前
FTT变换Matlab代码解释及应用场景
算法
许野平5 小时前
Rust: enum 和 i32 的区别和互换
python·算法·rust·enum·i32
chenziang16 小时前
leetcode hot100 合并区间
算法
chenziang16 小时前
leetcode hot100 对称二叉树
算法·leetcode·职场和发展
szuzhan.gy6 小时前
DS查找—二叉树平衡因子
数据结构·c++·算法
一只码代码的章鱼7 小时前
排序算法 (插入,选择,冒泡,希尔,快速,归并,堆排序)
数据结构·算法·排序算法