博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
HDU 4278 卡特兰,区间DP
阅读量:7029 次
发布时间:2019-06-28

本文共 1105 字,大约阅读时间需要 3 分钟。

题意:每个人有一个DI值,现在有一个小黑屋,这些人的顺序可以利用这个小黑屋调整,调整方式是入栈出栈方式,也就是说,这里的方案是有卡特兰数个方式。

调整后使得 d1*0 + d2*1 + d3*2 + d4*3 ...... 最小。

 

分析:这个题目竟然会是区间DP。

考虑区间 [ L, R ] ,那么L,可以从任意位置出栈,枚举出栈位置,可以划分为两个部分,也就是说两个子问题,但是如何利用这两个子问题得到 d[L,R],

d[L,R] = 前一部分 + D[L]*(i-L) + 后一部分 + 后一部分进位。

其中,后一部分的进位是一个前缀和*进多少位。

#include 
using namespace std;const int maxn = 105;const int inf = 0x3f3f3f3f;int a[maxn];int d[maxn][maxn];int su[maxn];int dp(int L,int R) { if(L>=R) return 0; if(d[L][R]!=-1) return d[L][R]; d[L][R] = inf; for(int i=L;i<=R;i++) { d[L][R] = min(d[L][R], dp(L+1, i)+(i-L)*a[L]+dp(i+1, R)+(su[R]-su[i])*(i+1-L)); } return d[L][R];}int main(){ //freopen("in.txt","r",stdin); int t; scanf("%d",&t); int kase = 1; while(t--) { int n; scanf("%d",&n); memset(d,-1,sizeof(d)); memset(su,0,sizeof(su)); for(int i=1;i<=n;i++) { scanf("%d",&a[i]); su[i] = su[i-1] + a[i]; //前缀和 } printf("Case #%d: %d\n",kase++,dp(1,n)); } return 0;}
View Code

 

转载于:https://www.cnblogs.com/TreeDream/p/7210252.html

你可能感兴趣的文章
SQLServer 数据库镜像+复制切换方案
查看>>
Postman初探
查看>>
仿淘宝头像上传功能(一)——前端篇。
查看>>
Eclipse通过集成svn实现版本控制
查看>>
OS开发过程中常用开源库
查看>>
关于在多个UItextield切换焦点
查看>>
hdu 2768
查看>>
git记住用户名密码
查看>>
ElasticSearch(2)-安装ElasticSearch
查看>>
从mysql数据表中随机取出一条记录
查看>>
ORACLE 锁表处理,解锁释放session
查看>>
深海机器人问题
查看>>
正则表达式(括号)、[中括号]、{大括号}的区别小结
查看>>
88.NODE.JS加密模块CRYPTO常用方法介绍
查看>>
java.net.ProtocolException: Exceeded stated content-length of: '13824' bytes
查看>>
asp.net 连接 oracle10g 数据库
查看>>
C 入门 第十一节
查看>>
HTML简单的注册页面搭建
查看>>
【06】Vue 之 组件化开发
查看>>
Docker 安装
查看>>