首页 > 其他 > 详细

Educational Codeforces Round 83 E. Array Shrinking

时间:2020-03-26 23:14:41      阅读:61      评论:0      收藏:0      [点我收藏+]

include <bits/stdc++.h>

define inf 0x3f3f3f3f

using namespace std;
const int maxn=550;
typedef long long ll;
int dp[maxn][maxn],val[maxn][maxn];

int main(){
int n;
scanf("%d",&n);
memset(dp,inf,sizeof(dp));
for(int i=1,x;i<=n;i++){
scanf("%d",&x);
dp[i][i]=1,val[i][i]=x;
}
for(int len=1;len<=n;len++){
for(int j=1;j+len<=n+1;j++){
int ends=j+len-1;
for(int i=j;i<ends;i++){
if(dp[j][i]1&&dp[i+1][ends]1&&val[j][i]==val[i+1][ends]){
dp[j][ends]=1;val[j][ends]=val[j][i]+1;
}
else dp[j][ends]=min(dp[j][ends],dp[j][i]+dp[i+1][ends]);
}
}
}
printf("%d\n",dp[1][n]);
return 0;
}

Educational Codeforces Round 83 E. Array Shrinking

原文:https://www.cnblogs.com/EchoZQN/p/12577914.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!