动态规划问题,输入方案,股票买卖问题,背包问题

1.输出股票的买卖时机,使利润最大,当然可能存在多种方案,只要输出一种即可

      这是需要缓存F数组,F[i] =max,则是i天卖出,然后去找之前买入时机就可以了

func maxProfit(prices []int) []int {
    // 输出买卖时机
    // [0,0]:表示没有交易,[1,3]:表示第1天买入,第3天卖出
    n :=len(prices)
    if n < 2{
        return []int{0,0}
    }
    f :=make([]int,n)
    min := prices[0]
    for i:=1;i<n;i++{
        f[i] = prices[i] - min
        if f[i] < f[i-1] {
            f[i] = f[i-1]
        }
        if min > prices[i]{
            min = prices[i]
        }
    }
    // 最大值是哪天获取的
    f_max,idx :=0,0
    for i:=0;i<n;i++{
        if f_max < f[i]{
            f_max= f[i]
            idx = i
        }
    }
    // 哪天买入的,idx前面的最小值
    min_idx, min :=0,prices[0]
    for i:=1;i<idx;i++{
        if min > prices[i]{
            min = prices[i]
            min_idx = i
        }
    }
    return []int{min_idx,idx}
}

2、同理,输出0-1背包问题的方案,也是有了F[i][j]二维数组,判断F[i][j] = max(F[i-1][j],F[i-1][j-v[i]] + w[i]),也是逆推的,比如F[3][10] = F[4][10],就说明物品4不在方案中

     背包问题,求路径时,上图很好的体现了其决策网络及其层次

3、背包问题模板很固定,有两个主要步骤,降维和二分类。

         比如根据选取数量将其分为1,2,3...n等,然后在选取k个物品时,将包含A和不包含A分为两类。

 

 

 

内容概要:本文介绍了基于贝叶斯优化的CNN-LSTM混合神经网络在时间序列预测中的应用,并提供了完整的Matlab代码实现。该模型结合了卷积神经网络(CNN)在特征提取方面的优势与长短期记忆网络(LSTM)在处理时序依赖问题上的强大能力,形成一种高效的混合预测架构。通过贝叶斯优化算法自动调参,提升了模型的预测精度与泛化能力,适用于风电、光伏、负荷、交通流等多种复杂非线性系统的预测任务。文中还展示了模型训练流程、参数优化机制及实际预测效果分析,突出其在科研与工程应用中的实用性。; 适合人群:具备一定机器学习基基于贝叶斯优化CNN-LSTM混合神经网络预测(Matlab代码实现)础和Matlab编程经验的高校研究生、科研人员及从事预测建模的工程技术人员,尤其适合关注深度学习与智能优化算法结合应用的研究者。; 使用场景及目标:①解决各类时间序列预测问题,如能源出力预测、电力负荷预测、环境数据预测等;②学习如何将CNN-LSTM模型与贝叶斯优化相结合,提升模型性能;③掌握Matlab环境下深度学习模型搭建与超参数自动优化的技术路线。; 阅读建议:建议读者结合提供的Matlab代码进行实践操作,重点关注贝叶斯优化模块与混合神经网络结构的设计逻辑,通过调整数据集和参数加深对模型工作机制的理解,同时可将其框架迁移至其他预测场景中验证效果。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值