算法板子

#include<bits/stdc++.h>
using namespace std;
const int N = 310;
int dp[N][N], a[N], s[N];
int n;
int main() {
    cin >> n;
    for (int i = 1; i <= n; ++i) {
        cin >> a[i];
        s[i] = s[i - 1] + a[i];
    }
    memset(dp, 0x3f, sizeof dp);
    for (int i = 1; i <= n; ++i) {
        for (int j = 1; j + i - 1 <= n; ++j) {
            int k = j + i - 1;
            if (i == 1) {
                dp[j][j] = 0;
                continue;
            }
            for (int l = j; l < k; ++l) {
                dp[j][k] = min(dp[j][k], dp[j][l] + dp[l + 1][k] + s[k] - s[j - 1]);
            }
        }
    }
    cout << dp[1][n] << endl;
    return 0;
}
本文为原创文章,欢迎分享,勿全文转载,如果内容你实在喜欢,可以加入收藏夹,说不定哪天故事又继续更新了呢。
本文地址:https://qoogle.top/merge-stones/
最后修改日期:2020年6月18日

作者

留言

撰写回覆或留言

发布留言必须填写的电子邮件地址不会公开。