A - 男神的礼物
Time Limit: 3000/3000MS (Java/Others) Memory Limit: 65535/65535KB (Java/Others)
Lweb学长是集训队里公认的男神。有一天他要给美美的学姐姐准备礼物。
Lweb学长可是会魔法的哟。为了准备一份礼物,男神要加工n份材料。每一次只能加工相邻的材料。
当男神加工两个魔法值为a,b的材料,男神都要消耗a*b的体力,同时在这个地方合成出魔法值(a+b)%100的材料。
男神为了能节省体力来完成他的礼物。想找聪明的你帮他算一算他所要花费的最小体力。
Input
第一行一个整数T,表示男神所要准备的礼物数。 之后的T组数据各有两行数据,第一行有一个整数n,表示这份礼物的材料数(1<=n<=100)。 接下来一行有n个整数a(0<=a<100),表示这件礼物第i份材料的魔法值。
Output
每组数据一行输出,表示男神制作这份礼物所要的最小体力。
Sample input and output
Sample Input | Sample Output |
---|---|
2 |
342 |
Hint
对于样例 2:
先加工材料40和60,得到0的材料,消耗40∗60体力,共消耗2400体力;
再加工材料0和20,得到20的材料,消耗0∗20体力,共消耗2400体力.
解题报告:
首先我们考虑最为简单的搜索算法来实现,但是可以发现,搜索树很深,且没有有效的剪枝手段,因此舍弃搜索算法.
稍微思考后我们发现此题可以用动态规划来实现,这是因为假如[l,r]这一段已经求解后,不会对后面的产生影响,即满足无后效性原则,且问题中包含有大量重叠子问题,故使用动态规划来解决本题.
令 f( i , j ) 表示将 [ i , j ]这一段材料合并所需的最小体力.
如何转移呢?
不难发现,我们只需枚举中间的位置即可
即
f ( i , j ) = min { f( i , u ) + f ( u + 1 , j ) + (sum[i] - sum[l-1]) * ( sum[r] – sum[i] ) }
注意到上式的sum[y] – sum[x] 都需对100取模,我们可以预处理出来.
#include <iostream>
#include <algorithm>
#include <cstring>
#include <cstdio> typedef long long ll;
using namespace std;
const int maxn = + ;
ll f[maxn][maxn];
ll sum[maxn];
ll h[maxn]; ll dp(int l,int r)
{
if (f[l][r] != -)
return f[l][r];
ll & ans = f[l][r] = ;
if (l == r)
return ans = ;
for(int i = l ; i < r ; ++ i )
ans = min(ans,dp(l,i) + dp(i+,r) + ( (sum[i] - sum[l-]) % ) * ((sum[r]-sum[i])%));
return ans;
} int main(int argc,char *argv[])
{
int Case,n;
scanf("%d",&Case);
sum[] = ;
while(Case--)
{
memset(f,-,sizeof(f));
scanf("%d",&n);
for(int i = ; i <= n ; ++ i)
{
int temp;
scanf("%d",&temp);
sum[i] = sum[i-] + temp;
}
printf("%lld\n",dp(,n));
}
return ;
}
UESTC_男神的礼物 2015 UESTC Training for Dynamic Programming<Problem A>的更多相关文章
-
UESTC_男神的约会 2015 UESTC Training for Dynamic Programming<;Problem J>;
J - 男神的约会 Time Limit: 3000/1000MS (Java/Others) Memory Limit: 65535/65535KB (Java/Others) Submit ...
-
UESTC_酱神的旅行 2015 UESTC Training for Dynamic Programming<;Problem M>;
M - 酱神的旅行 Time Limit: 3000/1000MS (Java/Others) Memory Limit: 65535/65535KB (Java/Others) Submit ...
-
UESTC_酱神赏花 2015 UESTC Training for Dynamic Programming<;Problem C>;
C - 酱神赏花 Time Limit: 3000/1000MS (Java/Others) Memory Limit: 262143/262143KB (Java/Others) Submi ...
-
UESTC_邱老师选妹子 2015 UESTC Training for Dynamic Programming<;Problem H>;
H - 邱老师选妹子 Time Limit: 3000/1000MS (Java/Others) Memory Limit: 65535/65535KB (Java/Others) Submi ...
-
UESTC_邱老师看电影 2015 UESTC Training for Dynamic Programming<;Problem F>;
F - 邱老师看电影 Time Limit: 3000/1000MS (Java/Others) Memory Limit: 65535/65535KB (Java/Others) Submi ...
-
UESTC_邱老师玩游戏 2015 UESTC Training for Dynamic Programming<;Problem G>;
G - 邱老师玩游戏 Time Limit: 3000/1000MS (Java/Others) Memory Limit: 65535/65535KB (Java/Others) Submi ...
-
UESTC_酱神寻宝 2015 UESTC Training for Dynamic Programming<;Problem O>;
O - 酱神寻宝 Time Limit: 3000/1000MS (Java/Others) Memory Limit: 65535/65535KB (Java/Others) Submit ...
-
UESTC_邱老师选妹子(二) 2015 UESTC Training for Dynamic Programming<;Problem I>;
I - 邱老师选妹子(二) Time Limit: 3000/1000MS (Java/Others) Memory Limit: 65535/65535KB (Java/Others) Su ...
-
UESTC_导弹拦截 2015 UESTC Training for Dynamic Programming<;Problem N>;
N - 导弹拦截 Time Limit: 3000/1000MS (Java/Others) Memory Limit: 65535/65535KB (Java/Others) Submit ...
随机推荐
-
bzoj1854 游戏
Description lxhgww最近迷上了一款游戏,在游戏里,他拥有很多的装备,每种装备都有2个属性,这些属性的值用[1,10000]之间的数表示.当他使用某种装备时,他只能使用该装备的某一个属性 ...
-
laravel中间件-----------middleware
middleware中间件 是访问到达服务器后在被对应的路由处理之前所经过的一层过滤层,故称中间件. 中间件是存放在app\http\middleware中,需要定一个 handle 处理方法,在ha ...
-
JSON (仅限本地)
<script type="text/javascript"> setInterval(function() { $("#content").loa ...
-
Codeforces 302D
思路:最短路,map[i][j] = d*(|x[i]-x[j]| + |y[i]-y[j]|) - add[i] #include<iostream> #include<cstdi ...
-
AIX上面Oracle数据库相关启动
1,启动停止Oracle实例 (1) su -oracle (2) echo $ORACLE_SID (3) sqlplus /nolog //以不登录到数据库的方式进入sqlplus环境 (4) c ...
-
PHP实现Collection数据集类及其原理
本文目录 : Collection源码 讲解与例子 ArrayAccess的使用 JsonSerializable的使用 Countable的使用 IteratorAggregate.ArrayIte ...
-
基于winserver部署Apollo初次体验(附.net客户端demo)
前言 配置中心伴随着这几年分布式系统演变和微服务架构的兴起,已经成为必不可少的需求之一.试下一下如果哪天公司的所有应用服务,从公司服务器迁移到云服务,成千上万的配置,修改起来是多么耗时费劲的事(我们公 ...
-
Java之Https请求
import java.io.BufferedReader; import java.io.InputStream; import java.io.InputStreamReader; import ...
-
asp.net—工厂模式
一.什么是工厂模式 定义:定义一个创建对象的接口,让其子类自己决定实例化哪一个工厂类. 二.怎么使用工厂模式 首先模拟一个场景:有一个汽车工厂, 可以日本车.美国车.中国车... 这个场景怎么用工厂 ...
-
testng生成报告 testng-xslt 美化测试报告
testng生成报告 testng-xslt 美化测试报告 testng生成报告 testng-xslt 美化测试报告 用TestNG测试后,自动会生成html的测试报告.利用 testNG-xslt ...