| 比赛 | 
    板子大赛 | 
    评测结果 | 
    AAAAAAAAAA | 
    | 题目名称 | 
    石子合并 | 
    最终得分 | 
    100 | 
    | 用户昵称 | 
    李奇文 | 
    运行时间 | 
    0.038 s  | 
    | 代码语言 | 
    C++ | 
    内存使用 | 
    4.03 MiB  | 
    | 提交时间 | 
    2025-01-22 16:27:23 | 
显示代码纯文本
#include<bits/stdc++.h> 
#define ll long long 
using namespace std;
ll n,a[305],f[305][305];
int main(){
	freopen("shizi.in","r",stdin);
	freopen("shizi.out","w",stdout);
    std::cin>>n;
    memset(f,0x3f,sizeof(f));
    for(ll i=1;i<=n;i++){
    	std::cin>>a[i];
    	a[i]+=a[i-1];
    	f[i][i]=0;
    }
    for(ll i=2;i<=n;i++){
    	for(ll j=1;j+i-1<=n;j++){
    		ll w=j+i-1;
    		for(ll k=j+1;k<=w;k++){
    			f[j][w]=min(f[j][w],f[j][k-1]+f[k][w]);
    		}
    		f[j][w]+=(a[w]-a[j-1]);
    	}
    }
    std::cout<<f[1][n]<<endl;
    return 0;
}