HRBUST - 1819 石子合并问题--圆形版(区间dp+环形+四边形优化)
石子合并问题--圆形版
在圆形操场上摆放着一行共n堆的石子。现要将石子有序地合并成一堆。规定每次只能选相邻的两堆合并成新的一堆,并将新的一堆石子数记为该次合并的得分。请编辑计算出将n堆石子合并成一堆的最小得分和将n堆石子合并成一堆的最大得分。
Input
输入有多组测试数据。
每组第一行为n(n<=100),表示有n堆石子,。
二行为n个用空格隔开的整数,依次表示这n堆石子的石子数量ai(0<ai<=100)
Output
每组测试数据输出有一行。输出将n堆石子合并成一堆的最小得分和将n堆石子合并成一堆的最大得分。 中间用空格分开。
Sample Input
3
1 2 3
Sample Output
9 11
#include<bits/stdc++.h>
#define MAX 205
#define INF 0x3f3f3f3f
using namespace std;
typedef long long ll; int a[MAX],sum[MAX];
int dp1[MAX][MAX],dp2[MAX][MAX];
int s[MAX][MAX]; int main()
{
int n,len,i,j,k;
while(~scanf("%d",&n)){
memset(dp1,INF,sizeof(dp1));
memset(dp2,,sizeof(dp2));
memset(s,,sizeof(s));
memset(sum,,sizeof(sum));
for(i=;i<=n;i++){
scanf("%d",&a[i]);
sum[i]=sum[i-]+a[i];
dp1[i][i]=;
s[i][i]=i;
}
for(i=n+;i<*n;i++){ //环形处理
sum[i]=sum[i-]+a[i-n];
dp1[i][i]=;
s[i][i]=i;
}
for(len=;len<=n;len++){
for(i=;i<*n-;i++){
j=i+len-;
if(j>*n-) break;
for(k=s[i][j-];k<=s[i+][j];k++){ //四边形优化求最小
if(dp1[i][j]>dp1[i][k]+dp1[k+][j]+sum[j]-sum[i-]){
dp1[i][j]=dp1[i][k]+dp1[k+][j]+sum[j]-sum[i-];
s[i][j]=k;
}
}
for(k=i;k<j;k++){
if(dp2[i][j]<dp2[i][k]+dp2[k+][j]+sum[j]-sum[i-]){
dp2[i][j]=dp2[i][k]+dp2[k+][j]+sum[j]-sum[i-];
}
}
}
}
int minn=INF,maxx=;
for(i=;i<=n;i++){
minn=min(minn,dp1[i][i+n-]);
maxx=max(maxx,dp2[i][i+n-]);
}
printf("%d %d\n",minn,maxx);
}
return ;
}
HRBUST - 1819 石子合并问题--圆形版(区间dp+环形+四边形优化)的更多相关文章
- HRBUST 1819 石子合并问题--圆形版
		石子合并问题--圆形版 Time Limit: 1000ms Memory Limit: 32768KB This problem will be judged on HRBUST. Original ... 
- HRBUST 1818 石子合并问题--直线版
		石子合并问题--直线版 Time Limit: 1000ms Memory Limit: 32768KB This problem will be judged on HRBUST. Original ... 
- CSU 1592 石子合并 (经典题)【区间DP】
		<题目链接> 题目大意: 现在有n堆石子,第i堆有ai个石子.现在要把这些石子合并成一堆,每次只能合并相邻两个,每次合并的代价是两堆石子的总石子数.求合并所有石子的最小代价. Input ... 
- NYOJ 石子合并(一)(区间DP)
		题目链接:http://acm.nyist.edu.cn/JudgeOnline/problem.php?pid=737 题目大意: 有N堆石子排成一排,每堆石子有一定的数量.现要将N堆石子并成为一堆 ... 
- 石子合并/能量项链【区间dp】
		题目链接:http://www.51mxd.cn/problem.php-pid=737.htm 题目大意:给出n个石子堆以及这n个石子堆中石子数目,每次操作合并两个相邻的石子堆,代价为两个石子堆数目 ... 
- NYOJ 石子合并(一) 区间dp入门级别
		描述 有N堆石子排成一排,每堆石子有一定的数量.现要将N堆石子并成为一堆.合并的过程只能每次将相邻的两堆石子堆成一堆,每次合并花费的代价为这两堆石子的和,经过N-1次合并后成为一堆.求出总的代价 ... 
- 以石子合并为例的区间DP
		区间DP,是一类具有较为固定解法的DP,一般的思路都是: first.初始化区间长度为1的情况(一般区间长度为1的较易于初始化) second. for(枚举区间长度2~n){ for(枚举左端点){ ... 
- nyoj737 石子合并(一) 区间DP
		dp[x][y]表示合并[x, y]区间的石子的最小花费,将区间长度递增枚举即可. AC代码: #include<cstdio> #include<algorithm> usi ... 
- HDU 2829 区间DP & 前缀和优化 & 四边形不等式优化
		HDU 2829 区间DP & 前缀和优化 & 四边形不等式优化 n个节点n-1条线性边,炸掉M条边也就是分为m+1个区间 问你各个区间的总策略值最少的炸法 就题目本身而言,中规中矩的 ... 
随机推荐
- framemarker的使用
			1 什么是framemarker framemarker是网页模版和数据模型的结合体.装载网页的时候,framemarker自动从数据模型中提取数据并生成html页面. 2 framemarker怎么 ... 
- The goroutine scheduler is not preemptive.
			go - Why is time.sleep required to run certain goroutines? - Stack Overflow https://stackoverflow.co ... 
- git 从远端拉取指定分支和推送本地某个分支到远端
			如题,可以直接从远端拉取某个分支,也可以直接将本地某个分支推送到远端. 原文链接:https://www.cnblogs.com/hamsterPP/p/6810831.html 
- tmux基本使用方法
			tmux是一款优秀的终端复用软件.tmux采用C/S模型构建,输入tmux命令就相当于开启了一个服务器,此时默认将新建一个会话,然后会话中默认新建一个窗口,窗口中默认新建一个面板. 一个tmux se ... 
- 4.1 《锋利的jQuery》jQuery中的事件
			$(document).ready()方法和window.onload方法的区别 事件绑定 合成事件 事件冒泡 事件对象的属性 tip1:停止事件冒泡和阻止默认行为都可以用return false替代 ... 
- win10系统使用clover时程序崩溃的解决
			1. 工具 ---> Internet选项 2. 程序选项卡 ---> 管理加载项 3.选择ExporerWatcher Class ---> 启用 win10对于未验证的程序状态 ... 
- 对于glut和freeglut的一点比较和在VS2013上的配置问题
			先大概说一下glut.h和freeglut.h 首先要知道openGL是只提供绘图,不管窗口的,所以你需要给它一个绘图的区域(openGL能跨平台也与此有些关系) glut.h和freeglut.h都 ... 
- C++之封装
			希望暴露public 希望隐藏private 对象实例化有两种方式,从栈实例化,从堆(new出来的)实例化. 以谁做什么作为核心. public 放前面,private放后面(属性可以定义为priva ... 
- BZOJ 1651 [Usaco2006 Feb]Stall Reservations 专用牛棚:优先队列【线段最大重叠层数】
			题目链接:http://www.lydsy.com/JudgeOnline/problem.php?id=1651 题意: 给你n个线段[a,b],问你这些线段重叠最多的地方有几层. 题解: 先将线段 ... 
- svn安装以及汉化过程
			第一步 下载svn地址 https://tortoisesvn.net/downloads.html 第二步一路next 最后finish 完成 就是完成svn的流程 第三步就是安装语言包 安装包语言 ... 
