蓝桥杯 算法提高 合并石子

这是一个动态规划的题,此题没有AC,只过了8个测试点,每次相邻两堆合成一堆

因为每次两堆合成一堆,则是第一堆的最小花费+第二堆的最小花费+两堆石子之和就是当前合成的最小花费

状态转移方程可以写为cost[i][j]=min(cost[i][k]+[k+1][j],cost[i][j])+d[j]-d[i]; i==0时要特殊处理一下

#include<iostream>
using namespace std;
const int N=1000+9;
typedef long long LL;
const LL INF=9999999999;
LL cost[N][N];//用于存储i---j两点的最小花费
LL d[N];//存储输入的数据 
int main()
{
	LL dp(int start,int end);
	int n;
	LL x;
	cin>>n;
	for(int i=0;i<n;i++)
	{
		cin>>d[i];
		if(i>0)d[i]+=d[i-1];//0~i石子之和,方便计算两堆石子之和 
	}
	for(int i=0;i<n;i++)
		for(int j=0;j<n;j++)
			cost[i][j]=INF;
	cout<<dp(0,n-1);
	return 0;
}

LL dp(int start,int end)
{
	if(end-start==0)	return 0;
	if(cost[start][end]<INF)return cost[start][end];
	else
		for(int i=start;i<end;i++)//状态转移 两堆最小的花费加上合并两堆的花费 
			cost[start][end]=min(cost[start][end],dp(start,i)+dp(i+1,end));
	if(start==0)return cost[start][end]+=d[end];//开头是0,则需要特殊处理 
	return cost[start][end]+=d[end]-d[start-1];//已经算的要记录下来,下次使用 
}


发布了25 篇原创文章 · 获赞 5 · 访问量 1万+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章