【算法|动态规划 | 区间dp No.1】AcWing 282. 石子合并

淩亂°似流年 2024-04-27 07:02 177阅读 0赞

个人主页:兜里有颗棉花糖
欢迎 点赞? 收藏✨ 留言✉ 加关注?本文由 兜里有颗棉花糖 原创
收录于专栏【AcWing算法提高学习专栏】【手撕算法系列专栏】
?本专栏旨在提高自己算法能力的同时,记录一下自己的学习过程,希望对大家有所帮助
?希望我们一起努力、成长,共同进步

原题链接:点击直接跳转到该题目

目录

  • 1️⃣题目描述
  • 2️⃣题目解析
  • 3️⃣解题代码

1️⃣题目描述

在这里插入图片描述
在这里插入图片描述

2️⃣题目解析

状态表示:dp[i][j]表示合并区间[i,j]的石头所需要的最小代价。

状态转移方程:dp[i][j] = dp[i][k] + dp[k + 1][j] + sum[i][j]

注意:k的取值范围是i <= k < j

返回值:dp[1][n]

3️⃣解题代码

  1. #include<iostream>
  2. #include<cstdio>
  3. #include<cstring>
  4. #include<algorithm>
  5. using namespace std;
  6. const int N = 310;
  7. int arr[N],sum[N];
  8. int dp[N][N];
  9. int main()
  10. {
  11. int n;
  12. cin >> n;
  13. for(int i = 1;i <= n;i++) cin >> arr[i],sum[i] = sum[i - 1] + arr[i];
  14. for(int len = 2;len <= n;len++)
  15. {
  16. for(int i = 1;i + len - 1 <= n;i++)
  17. {
  18. int j = i + len - 1;
  19. dp[i][j] = 1e8;
  20. for(int k = i;k < j;k++)
  21. {
  22. dp[i][j] = min(dp[i][j],dp[i][k] + dp[k + 1][j] + sum[j] - sum[i - 1]);
  23. }
  24. }
  25. }
  26. cout << dp[1][n] << endl;
  27. return 0;
  28. }

最后就ac通过啦!!!

发表评论

表情:
评论列表 (有 0 条评论,177人围观)

还没有评论,来说两句吧...

相关阅读

    相关 石子合并问题 (区间dp

    石子合并问题是最经典的DP问题。首先它有如下3种题型: (1)有N堆石子,现要将石子有序的合并成一堆,规定如下:每次只能移动任意的2堆石子合并,合并花费为新合成的

    相关 282 石子合并(区间dp

    1. 问题描述: 设有 N 堆石子排成一排,其编号为 1,2,3,…,N。每堆石子有一定的质量,可以用一个整数来描述,现在要将这 N 堆石子合并成为一堆。每次只能合并相邻的两

    相关 ACM DP 石子合并问题

    滴,集训第二十一天打卡。 可能是对组队不太满意,都不大高兴做新的训练... 所以最近一直在磨DP,翻一下博客,发现最近都是DP啊... 这个石子合并的,我做的训练数据n是