CODEVS1048石子归并
来源:互联网 发布:遗传算法编码方式 编辑:程序博客网 时间:2024/06/06 03:01
题目描述
有n堆石子排成一列,每堆石子有一个重量w[i], 每次合并可以合并相邻的两堆石子,一次合并的代价为两堆石子的重量和w[i]+w[i+1]。问安排怎样的合并顺序,能够使得总合并代价达到最小。
输入描述
第一行一个整数n(n<=100)
第二行n个整数w1,w2…wn (wi <= 100)
输出描述
一个整数表示最小合并代价
样例输入
4
4 1 1 4
样例输出
18
序列型DP,选择归并长度,枚举起点终点,进行DP即可水过
看到有优化,但我懒得写,请看http://blog.csdn.net/abcjennifer/article/details/5805330
#include<iostream>#include<cstdio>using namespace std;const int N=105;int w[N],s[N][N],f[N][N];int main(){ int n,i,j,k,l; cin>>n; for(i=1;i<=n;i++) cin>>w[i]; for(i=1;i<=n;i++) { f[i][i]=0; s[i][i]=w[i]; for(j=i+1;j<=n;j++) s[i][j]=s[i][j-1]+w[j]; } for(l=2;l<=n;l++) for(i=1;i<=n-l+1;i++) { j=i+l-1; f[i][j]=2147483647; for(k=i;k<=j-1;k++) if(f[i][j]>f[i][k]+f[k+1][j]+s[i][j]) f[i][j]=f[i][k]+f[k+1][j]+s[i][j]; } cout<<f[1][n];//最大区间最小合并代价 return 0;}
1 0
- 【codevs1048】 石子归并
- CODEVS1048石子归并
- [codevs1048]石子归并
- codevs1048 石子归并(区间DP)
- 石子归并 Codevs1048 Codevs2102 Codevs3002
- 石子归并 【区间DP】 Codevs1048
- codevs1048 石子归并 动态规划dp
- 【日常学习】【区间DP】codevs1048 石子归并题解
- 【codevs1048】【codevs1154&&06TG】石子归并、能量项链,序列dp的典型题目
- 【codevs1048】【codevs1154&&06TG】石子归并、能量项链,序列dp的典型题目
- 【codevs1048】石子归并——论打代码前洗脸的重要性
- codevs1048
- 石子归并
- 石子归并
- 石子归并
- 石子归并
- 石子归并
- 石子归并
- pandas小记:pandas基本设置
- 从性能角度看前缀++和后缀++(++i和i++的深入剖析)
- nodejs初学到express框架使用
- QtDesigner:Calculator Builder Example
- CString::TrimLeft和CString::TrimRight
- CODEVS1048石子归并
- 第一个cocos2dx-lua游戏--蚂蚁进洞
- 51nod 1368:黑白棋 二分图最大匹配
- 八皇后——递归学习
- 主线程和子线程的同步控制
- 1040. 有几个PAT(25)
- 磁盘驱动器
- ——黑马程序员——C语言中一维数组基本概念和初始化
- mysql5.6.26改变默认数据目录问题