算法设计与分析——动态规划——最大字段和问题

本文探讨了如何使用动态规划解决最大字段和问题。通过自底向上的方法,逐步缩小问题规模,利用子问题的最优解来构建原问题的最优解。在过程中,避免重复计算并维护一个数组来保存最优解。递归方程为:b[i] = max(b[i-1] + a[i], a[i]),其中b存储最优解,a为字段序列。" 115721211,8753399,Qt Creator设计模式下的QML编辑体验,"['Qt开发', '图形用户界面', 'QML编程', '设计工具', 'UI设计']
摘要由CSDN通过智能技术生成

动态规划解决问题是自底向上。原问题的规模是n个元
素。这n个元素不好考虑,我们先考虑n-1个元素,这样还不好考
虑,我们考虑n-2个元素,这样依次递减,最后问题规模变成一个
元素。但是我们发现,在递减的过程中间,子问题的最优解包含
在原问题的最优解之中,而且子问题的解还有一些是重复的。
因此,使用动态规划来解决这个问题。

思想:
对字段序列进行一个循环,
如果之前的序列b>0,则加入这个新的序列之中;
如果之前的序列b<=0,则重新设置字段的序列和为nums[i];
如果之前的序列加上nums[i],的值大于之前的最大序列和,则更新最大序列和;
我们要写出一个递归方程。我们设置一个数组b来存放最优解,首先将b[1]=a[1],a存放的是我们的n个元素。第i个元素,他的状态就是将他放不放到数组b中(和之前的有些像)。因此,递归方程就是:b[i]=max{b[i-1]+a[i],a[i]}

#include<iostream>
using namespace std;

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值