蓝桥杯DP算法——区间DP(C++)

根据题意要求的是将石子合并的最小权值,我们可以根据DP思想使用二维数组f[i,j]来存放所有从第i堆石子到第j堆石子合并成一堆石子的合并方式。

然后由第二个图所示,我们可以将i到j区间分成两个区间,因为将i到j合并成一个区间的前一步一定是合并前两个区间。因此我们可以将状态计算的递归定义为区间的中间,通过变化区间的中间来寻找合并i到j的最小值。

也就是f[i,j]=min(f[i,k]+f[k+1,j]+s[j]-s[i-1]

例题:https://www.acwing.com/problem/content/284/

cpp 复制代码
#include<iostream>
using namespace std;

const int N=310;
int n;
int f[N][N];
int s[N];

int main()
{
    cin>>n;
    int a;
    for(int i=1;i<=n;i++) //前缀和
    {
        scanf("%d",&a);
        s[i]=s[i-1]+a;
    }
    
    
    for(int len=2;len<=n;len++)
    {
        for(int i=1;i+len-1<=n;i++)
        {
            int l=i ,r=i+len-1;
            f[l][r]=1e8;
            for(int k=l;k<r;k++)
            {
                f[l][r]=min(f[l][r],f[l][k]+f[k+1][r]+s[r]-s[l-1]);
            }
        }
    }
    
    cout<<f[1][n];
    return 0;
}

k的取值范围:

这里划分出的区间是[l, k], [k+1, r]

说明: [l, l] [r, r] 这两个区间都是不为空的,至少包含了一堆石子。

前提:划分出的两个区间都不为空的情况下,讨论k的取值范围

所以,对于[l, k] k可以取到 l 对于[k+1, r] , 因为k+1 <= r, 所以 k <= r - 1, 即 k < r

相关推荐
青松@FasterAI5 小时前
【大模型面试】大模型(LLMs)高频面题全面整理(★2025年5月最新版★)
面试·职场和发展·大模型开发·大模型面试·nlp面试·nlp面题·大模型面题
爱吃涮毛肚的肥肥(暂时吃不了版)6 小时前
仿腾讯会议——创建房间&加入房间
c++·qt·面试·职场和发展·腾讯会议
Kidddddult7 小时前
力扣刷题Day 37:LRU 缓存(146)
算法·leetcode·力扣
生信碱移7 小时前
TCGA数据库临床亚型可用!贝叶斯聚类+特征网络分析,这篇 NC 提供的方法可以快速用起来了!
人工智能·python·算法·数据挖掘·数据分析
测试老哥7 小时前
Selenium使用指南
自动化测试·软件测试·python·selenium·测试工具·职场和发展·测试用例
wang__123007 小时前
力扣1812题解
算法·leetcode·职场和发展
_Power_Y8 小时前
面试算法刷题练习1(核心+acm)
算法·面试
@电子爱好者8 小时前
Vscode+git笔记
linux·职场和发展
Leo来编程8 小时前
算法-时间复杂度和空间复杂度
算法
Echo``9 小时前
2:点云处理—3D相机开发
人工智能·笔记·数码相机·算法·计算机视觉·3d·视觉检测