首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

算法导论之最大子段和

《算法导论》一书中对最大字段和可谓讲的是栩栩如生,楚楚动人。如果简单的说最大字段和,没有意义。而《算法导论》上举了一个股票的例子。...根据股票每天结束的价格来求出一段时间内何时买入何时卖出能是收益最大。...把问题做一个转换,求出相邻天数的股票价格的差值(周二 - 周一 = 差值),然后求出连续天数差值和的最大值,即为最大收益,所以就是最大子段和的问题。   ...还有一点说明的是算法的实现是和语言没有关系的,下面是用OC来实现的,你也可以用Java, PHP, C++等你拿手的语言进行实现,算法注重的还是思想。   ...如果数组中又两个数那么就是两个数的和,运行结果如下: ?       下面是10个数据运行的结果,最大子数组肯定是包括array[mid]这一项的,因为我们求得就是过中点的最大字段和。 ?

1K70
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    【题解】最大子段和

    题目描述 给出一个长度为 n 的序列 a,选出其中连续且非空的一段使得这段和最大。 输入格式 第一行是一个整数,表示序列的长度 n。...输入输出样例 输入 #1 7 2 -4 3 -1 2 -4 3 输出 #1 4 说明/提示 样例 1 解释 选取 [3,5] 子段 {3,−1,2},其和为 4。...仔细阅读题目,可发现题目要求的是连续且非空的最大子段和。 若用暴力方式处理复杂度为 图片 根据数据范围明显不可取。此时,可发现又是一个对连续区间的维护问题,那么我们尝试从其他的角度进行思考。...该区间元素必须连续,那么当碰见一个新的元素,无非出现两种情况: 该元素与之前的连续区间加起来的和比较大 该元素与之前的连续区间加起来的和还没有这个元素本身大 如果是情况1,那么连续区间总和就加上新增元素...和前面的一段组成新序列 */ int main(){ int n; int sum=0;//连续序列和 int ans=-1e9;//最大连续序列和 cin>>n;

    30210

    对最大子段和的理解(动态规划)

    问题 对一个长度为n的数组,找到连续的子段,使它的和在所有子段中是最大的。 比如3,4,-9,6。他们的最大子段和是7。...解法 A.遍历 O(n)=n^2 B.分治算法 O(N)=N*logN 数组分为Left与Right部分,最大字段和要么在left,要么在right,要么必然包括mid-1与mid+1(这种情况复杂度仅为...左最大子段和5,右最大子段和15,经过3与-5的最大子段和15。三者选最大的15作为结果。 C.动态规划 将输入数组描述为a1到an的整数序列,令bj为a1到aj序列中包含aj的最大子段和。...此时最大子段和仍然要么在左边,要么从mid+1向左找,但向左找的过程可以简化成常数时间(不直接找最大子段和,而是找b,仅仅找经过aj的最大子段和),也就是说不用考虑mid+1以外的项开头的段。...可以看出来,无论是a2还是a1+a2,都可以和a3连起来,选择max(a2,a1+a2)+a3或a3就选择了最大子段和。

    91530

    蓝桥杯 最大子阵(前缀和+最大子段)--------C语言—菜鸟级

    /* 给定一个n*m的矩阵A,求A中的一个非空子矩阵,使这个子矩阵中的元素和最大。 其中,A的子矩阵指在A中行和列均连续的一块。 样例说明 取最后一列,和为10。...输入 输入的第一行包含两个整数n, m,分别表示矩阵A的行数和列数。 接下来n行,每行m个整数,表示矩阵A。 输出 输出一行,包含一个整数,表示A中最大的子矩阵中的元素和。...样例输入 3 3 -1 -4 3 3 4 -1 -5 -2 8 样例输出 10 提示 思路: 行的前缀和(对行区间求和) + 最大子段原理 (对列区间求和) */ #include #include int main() { long int xsum[502][502];//xsum[i][j]前 i 行 j列的前缀和 long int i,...} for(i=1;i大子段 原理 求和 for(j=i;j<=n;j++) { ans=0; for(k=1;k<

    44320

    贪心算法:最大子序和

    最大子序和 题目地址:https://leetcode-cn.com/problems/maximum-subarray/ 给定一个整数数组 nums ,找到一个具有最大和的连续子数组(子数组最少包含一个元素...局部最优:当前“连续和”为负数的时候立刻放弃,从下一个元素重新计算“连续和”,因为负数加上下一个元素 “连续和”只会越来越小。...全局最优:选取最大“连续和” 「局部最优的情况下,并记录最大的“连续和”,可以推出全局最优」。...「这相当于是暴力解法中的不断调整最大子序和区间的起始位置」。 「那有同学问了,区间终止位置不用调整么? 如何才能得到最大“连续和”呢?」...例如如下代码: if (count > result) result = count; 「这样相当于是用result记录最大子序和区间和(变相的算是调整了终止位置)」。 如动画所示: ?

    84520

    ☆打卡算法☆LeetCode 53、最大子序和 算法解析

    一、题目 1、算法题目 “给定一个整数数组,找到最大和的连续子数组,返回其最大和。” 题目链接: 来源:力扣(LeetCode) 链接:53....最大子序和 - 力扣(LeetCode) (leetcode-cn.com) 2、题目描述 给定一个整数数组 nums ,找到一个具有最大和的连续子数组(子数组最少包含一个元素),返回其最大和。...示例 1: 输入: nums = [-2,1,-3,4,-1,2,1,-5,4] 输出: 6 解释: 连续子数组 [4,-1,2,1] 的和最大,为 6 。...这取决于nums[i]和f[i-1]+nums[i]谁更大,所以就可以推到出动态规划转移方程: f(i)=max{f(i-1)+nums[i],nums[i]} 2、代码实现 代码参考: public...我回顾我最光辉的时刻 就是和不同人在一起,变得更好的最长连续时刻

    29720

    最大子序列和问题之算法优化

    在这个问题中,最大子序列和可能在三处出现:即左半部序列、右半部序列、穿过中部从而占据左右两半部分的序列。前两种情况可以通过递归求解。...故该序列的最大子序列和为max(6,4,0)= 6。 时间复杂度分析: 假设T(n)为求解大小为n的最大子序列和问题所花费的时间。...算法四: 算法三利用递归较好的解决了最大子序列和问题,但仔细分析,在递归过程中,同一个元素很可能多次被操作,有没有更高效的算法?先上代码!...)如果大于0,不管当i > t的元素大小如何,加上thisSum总会使之后的和变大,而如果thisSum小于0,肯定会使之后的和变小 ,既然还会变小,那干脆就重新来过(thisSum = 0),有些另起炉灶的意味...不仅如此,在任意时刻,该算法都能对它已经读入的数据给出子序列问题的正确答案(其他算法即前三种不具有这个特性)。具有这种特性的算法叫做联机算法(online algorithm)。

    1.1K70

    最大子序列和问题之算法优化

    在这个问题中,最大子序列和可能在三处出现:即左半部序列、右半部序列、穿过中部从而占据左右两半部分的序列。前两种情况可以通过递归求解。...故该序列的最大子序列和为max(6,4,0)= 6。 时间复杂度分析: 假设T(n)为求解大小为n的最大子序列和问题所花费的时间。...---- 算法四: 算法三利用递归较好的解决了最大子序列和问题,但仔细分析,在递归过程中,同一个元素很可能多次被操作,有没有更高效的算法?...)如果大于0,不管当i > t的元素大小如何,加上thisSum总会使之后的和变大,而如果thisSum小于0,肯定会使之后的和变小,既然还会变小,那干脆就重新来过(thisSum = 0),有些另起炉灶的意味...不仅如此,在任意时刻,该算法都能对它已经读入的数据给出子序列问题的正确答案(其他算法即前三种不具有这个特性)。具有这种特性的算法叫做联机算法(online algorithm)。

    74630

    Python|贪心算法解最大子序和

    2 思路描述 第一时间想到的当然是暴力解决,基本思路就是遍历一遍,用两个变量,一个记录最大的和,一个记录当前的和。...后面发现可以用贪心算法来解比较简单其基本思路是正在访问的节点值+此节点之前的最大值如果大于当前节点,则更新最大值为和,否则更新最大值为当前节点。...以该元素为起点继续找最大子序列, # 并记录此时的最大值 max_ = max(max_, tmp, tmp+nums[i], nums[i])...tmp = nums[i] print(max_) 4 贪心算法的代码 nums=[-2,1,-3,4,-1,2,1,-5,4] lenth = len(nums) cur_sum...若下一个数据和部分最优解连在一起不再是可行解时,就不把该数据添加到部分解中,直到把所有数据枚举完,或者不能再添加算法停止。

    79310
    领券