【石子合并】

题目

错解

cpp 复制代码
#include <bits/stdc++.h>
using namespace std;
const int N = 310;
int a[N], s[N], f[N][N];
int main()
{
    int n;
    cin >> n;
    memset(f, 0x3f, sizeof f);
    for(int i = 1; i <= n; i++)
    {
        cin >> a[i];
        s[i] = s[i-1] + a[i];
        f[i][i] = 0;
    }
    for(int i = 1; i < n; i++)
    {
        for(int j = i+1; j <= n; j++)
        {
            for(int k = i; k < j; k++)
            {
                f[i][j] = min(f[i][j], f[i][k] + f[k+1][j] + s[j] - s[i-1]);
            }
        }
    }
    cout << f[1][n];
}

分析

应该从小区间遍历到大区间。因为这个更新方向是从小到大(先整合一小部分,再整合大部分),而不是从左到右、从上往下。

正解

cpp 复制代码
#include <bits/stdc++.h>
using namespace std;
const int N = 310;
int a[N], s[N], f[N][N];
int main()
{
    int n;
    cin >> n;
    memset(f, 0x3f, sizeof f);
    for(int i = 1; i <= n; i++)
    {
        cin >> a[i];
        s[i] = s[i-1] + a[i];
        f[i][i] = 0;
    }
    for(int len = 2; len <= n; len++)
    {
        for(int i = 1; i + len -1 <= n; i++)
        {
            int j = i + len - 1;
            for(int k = i; k < j; k++)
            {
                f[i][j] = min(f[i][j], f[i][k] + f[k+1][j] + s[j] - s[i-1]);
            }
        }
    }
    cout << f[1][n];
    return 0;
}
相关推荐
Tianwen_Burning17 分钟前
c++ release下的debug
c++
谦宸、墨白30 分钟前
从零开始学C++:二叉树进阶
开发语言·数据结构·c++
hrrrrb1 小时前
【算法设计与分析】贪心算法
算法·贪心算法·代理模式
TracyCoder1231 小时前
LeetCode Hot100(10/100)—— 53. 最大子数组和
算法·leetcode
Howrun7771 小时前
C++ 文件操作全知识点详细讲解
c++
Σίσυφος19002 小时前
霍夫变换vs LS vs RANSAC 拟合直线 MATLAB实现
算法·计算机视觉·matlab
假女吖☌2 小时前
限流算法-redis实现与java实现
java·redis·算法
蒟蒻的贤2 小时前
两数之和。
算法
wen__xvn2 小时前
代码随想录算法训练营DAY27第八章 贪心算法 part01
算法·贪心算法
We་ct2 小时前
LeetCode 125. 验证回文串:双指针解法全解析与优化
前端·算法·leetcode·typescript