UESTC_男神的礼物 2015 UESTC Training for Dynamic Programming

时间:2022-05-25 10:18:38

A - 男神的礼物

Time Limit: 3000/3000MS (Java/Others)     Memory Limit: 65535/65535KB (Java/Others)
Submit Status

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
2
18 19
3
40 60 20
342
2400

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>的更多相关文章

  1. UESTC&lowbar;男神的约会 2015 UESTC Training for Dynamic Programming&lt&semi;Problem J&gt&semi;

    J - 男神的约会 Time Limit: 3000/1000MS (Java/Others)     Memory Limit: 65535/65535KB (Java/Others) Submit ...

  2. UESTC&lowbar;酱神的旅行 2015 UESTC Training for Dynamic Programming&lt&semi;Problem M&gt&semi;

    M - 酱神的旅行 Time Limit: 3000/1000MS (Java/Others)     Memory Limit: 65535/65535KB (Java/Others) Submit ...

  3. UESTC&lowbar;酱神赏花 2015 UESTC Training for Dynamic Programming&lt&semi;Problem C&gt&semi;

    C - 酱神赏花 Time Limit: 3000/1000MS (Java/Others)     Memory Limit: 262143/262143KB (Java/Others) Submi ...

  4. UESTC&lowbar;邱老师选妹子 2015 UESTC Training for Dynamic Programming&lt&semi;Problem H&gt&semi;

    H - 邱老师选妹子 Time Limit: 3000/1000MS (Java/Others)     Memory Limit: 65535/65535KB (Java/Others) Submi ...

  5. UESTC&lowbar;邱老师看电影 2015 UESTC Training for Dynamic Programming&lt&semi;Problem F&gt&semi;

    F - 邱老师看电影 Time Limit: 3000/1000MS (Java/Others)     Memory Limit: 65535/65535KB (Java/Others) Submi ...

  6. UESTC&lowbar;邱老师玩游戏 2015 UESTC Training for Dynamic Programming&lt&semi;Problem G&gt&semi;

    G - 邱老师玩游戏 Time Limit: 3000/1000MS (Java/Others)     Memory Limit: 65535/65535KB (Java/Others) Submi ...

  7. UESTC&lowbar;酱神寻宝 2015 UESTC Training for Dynamic Programming&lt&semi;Problem O&gt&semi;

    O - 酱神寻宝 Time Limit: 3000/1000MS (Java/Others)     Memory Limit: 65535/65535KB (Java/Others) Submit  ...

  8. UESTC&lowbar;邱老师选妹子&lpar;二&rpar; 2015 UESTC Training for Dynamic Programming&lt&semi;Problem I&gt&semi;

    I - 邱老师选妹子(二) Time Limit: 3000/1000MS (Java/Others)     Memory Limit: 65535/65535KB (Java/Others) Su ...

  9. UESTC&lowbar;导弹拦截 2015 UESTC Training for Dynamic Programming&lt&semi;Problem N&gt&semi;

    N - 导弹拦截 Time Limit: 3000/1000MS (Java/Others)     Memory Limit: 65535/65535KB (Java/Others) Submit  ...

随机推荐

  1. bzoj1854 游戏

    Description lxhgww最近迷上了一款游戏,在游戏里,他拥有很多的装备,每种装备都有2个属性,这些属性的值用[1,10000]之间的数表示.当他使用某种装备时,他只能使用该装备的某一个属性 ...

  2. laravel中间件-----------middleware

    middleware中间件 是访问到达服务器后在被对应的路由处理之前所经过的一层过滤层,故称中间件. 中间件是存放在app\http\middleware中,需要定一个 handle 处理方法,在ha ...

  3. JSON &lpar;仅限本地&rpar;

    <script type="text/javascript"> setInterval(function() { $("#content").loa ...

  4. Codeforces 302D

    思路:最短路,map[i][j] = d*(|x[i]-x[j]| + |y[i]-y[j]|) - add[i] #include<iostream> #include<cstdi ...

  5. AIX上面Oracle数据库相关启动

    1,启动停止Oracle实例 (1) su -oracle (2) echo $ORACLE_SID (3) sqlplus /nolog //以不登录到数据库的方式进入sqlplus环境 (4) c ...

  6. PHP实现Collection数据集类及其原理

    本文目录 : Collection源码 讲解与例子 ArrayAccess的使用 JsonSerializable的使用 Countable的使用 IteratorAggregate.ArrayIte ...

  7. 基于winserver部署Apollo初次体验(附&period;net客户端demo)

    前言 配置中心伴随着这几年分布式系统演变和微服务架构的兴起,已经成为必不可少的需求之一.试下一下如果哪天公司的所有应用服务,从公司服务器迁移到云服务,成千上万的配置,修改起来是多么耗时费劲的事(我们公 ...

  8. Java之Https请求

    import java.io.BufferedReader; import java.io.InputStream; import java.io.InputStreamReader; import ...

  9. asp&period;net—工厂模式

    一.什么是工厂模式 定义:定义一个创建对象的接口,让其子类自己决定实例化哪一个工厂类. 二.怎么使用工厂模式 首先模拟一个场景:有一个汽车工厂,  可以日本车.美国车.中国车... 这个场景怎么用工厂 ...

  10. testng生成报告 testng-xslt 美化测试报告

    testng生成报告 testng-xslt 美化测试报告 testng生成报告 testng-xslt 美化测试报告 用TestNG测试后,自动会生成html的测试报告.利用 testNG-xslt ...