码迷,mamicode.com
首页 > 其他好文 > 详细

Codeforces 229D

时间:2014-07-21 14:30:46      阅读:206      评论:0      收藏:0      [点我收藏+]

标签:style   blog   color   数据   io   for   

一 题意描述:

有n(1<=n<=5,000)座塔排在一条直线上,从左到右每个塔的高度分别为hi(1<=hi<=100,000),每次操作你可以选择一座塔(假设是第i座),用吊车把它吊起来,然后放到与它相邻的一座塔上(可以是第i-1座也可以是第i+1座),这样,新塔的高度为两座塔的和,完成操作后,塔的总数减少一座。问最少需要多少次操作可以使得所有的塔从左到右形成一个非递减序列。

二 思路分析:

设dp[i]表示使前i座塔呈现非递减所需要的最小步骤数目,那么合并[j,i]座塔需要i-j步.

那么我们可以求得dp方程:dp[i]=min{dp[j]+i-j-1  |  j<i,h(j+1)+h(j+2)+·····+h(i)>=last[j]}

三 源码展示:

 1 #include <cstdio>
 2 int dp[5010],sum[5010],last[5010];
 3 int main()
 4 {
 5     int n;
 6     scanf("%d",&n);
 7     memset(sum,0,sizeof(sum));//把sum首先置为0,然后开始输入数据并逐步累加
 8    dp[0]=0;last[0]=0;
 9     for(int i = 1;i <= n;i++)
10     {
11         int a;
12         scanf("%d",&a);
13         sum[i]=sum[i-1]+a;
14         dp[i]=last[i]=1<<30;//初始值设为2的30次方大
15     }
16     for(int i=1;i<=n;i++)
17     {
18         for(int j=0;j<i;j++)
19         {
20             if(sum[i]-sum[j]>=last[j]&&dp[i]>=dp[j]+i-j-1)
21             {
22                 dp[i]=dp[j]+i-j-1;
23                 if(last(i)>sum[i]-sum[j]) last[i]=sum[i]-sum[j];
24             }
25         }
26     }
27     printf("%d\n",dp[n]);
28     return 0;
29 }

Codeforces 229D,布布扣,bubuko.com

Codeforces 229D

标签:style   blog   color   数据   io   for   

原文地址:http://www.cnblogs.com/khbcsu/p/3858122.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!