传送门:http://www.lydsy.com/JudgeOnline/problem.php?id=4897

【题解】

第一次看这题想的是f[l,r]的区间dp发现仅记录这两个好像不能转移啊

会出现abaca这种情况,也就是拿走的段在原序列中不连续。

考虑为什么会出现这个情况,肯定是这三个a里的元素十分集中,我们才会留着等合并后取。

我们离散值域,记f[l,r,nl,nr]表示[l,r]区间内,剩下[nl,nr]没拿走的min代价。

特别的如果nl=nr=0就表示全拿走了。

那么考虑f[l,r,nl,nr]怎么转移。

首先转移满足区间性质,也就是可以分割,所以

f[l,r,nl,nr]=min(f[l,k,nl,nr]+f[k+1,r,nl,nr], f[l,k,nl,nr]+f[k+1,r,0,0], f[l,k,0,0]+f[k+1,r,nl,nr])

然后考虑f[l,r,0,0]的转移:我要取完这个区间,要么是一次性取完:f[l,r,0,0]=min(f[l,r,0,0], a+b(Max[l..r]-Min[l..r])^2)

要么是留着[x,y]区间,最后取这个区间:f[l,r,0,0] = min(f[l,r,x,y]+a+b(y-x)^2)

然后转移就行啦,复杂度O(n^5)

# include <vector>
# include <stdio.h>
# include <string.h>
# include <iostream>
# include <algorithm>
// # include <bits/stdc++.h> using namespace std; typedef long long ll;
typedef long double ld;
typedef unsigned long long ull;
const int M = + ;
const int mod = 1e9+; # define RG register
# define ST static int n, m, A, B, a[M], w[M];
ll f[M][M][M][M];
bool vf[M][M][M][M];
vector<int> ps; inline ll dp(int l, int r, int nl, int nr) {
if(vf[l][r][nl][nr]) return f[l][r][nl][nr];
vf[l][r][nl][nr] = ;
ll ret = 1e18;
if(nl == && nr == ) {
int mx = -1e9, mi = 1e9;
for (int i=l; i<=r; ++i) mx = max(mx, w[i]), mi = min(mi, w[i]);
f[l][r][][] = A + (ll)B * (ps[mx-]-ps[mi-]) * (ps[mx-]-ps[mi-]);
for (int i=; i<=m; ++i)
for (int j=i; j<=m; ++j)
ret = min(ret, dp(l, r, i, j) + A + (ll)B * (ps[j-]-ps[i-]) * (ps[j-]-ps[i-]));
return f[l][r][][] = ret;
}
if(l == r) {
if(nl <= w[l] && w[l] <= nr) ret = ;
return f[l][r][nl][nr] = ret;
}
for (int k=l; k<r; ++k) {
ret = min(ret, dp(l, k, nl, nr) + dp(k+, r, nl, nr));
ret = min(ret, dp(l, k, nl, nr) + dp(k+, r, , ));
ret = min(ret, dp(l, k, , ) + dp(k+, r, nl, nr));
}
return f[l][r][nl][nr] = ret;
} int main() {
cin >> n >> A >> B;
for (int i=; i<=n; ++i) {
scanf("%d", a+i);
ps.push_back(a[i]);
}
sort(ps.begin(), ps.end());
ps.erase(unique(ps.begin(), ps.end()), ps.end());
m = ps.size();
for (int i=; i<=n; ++i)
w[i] = lower_bound(ps.begin(), ps.end(), a[i]) - ps.begin() + ;
cout << dp(, n, , );
return ;
}

bzoj4897 [Thu Summer Camp2016]成绩单的更多相关文章

  1. BZOJ4897: [Thu Summer Camp2016]成绩单【DP of DP】

    Description 期末考试结束了,班主任L老师要将成绩单分发到每位同学手中.L老师共有n份成绩单,按照编号从1到n的顺序叠 放在桌子上,其中编号为i的成绩单分数为w_i.成绩单是按照批次发放的. ...

  2. BZOJ4897 [Thu Summer Camp2016]成绩单 【dp】

    题目链接 BZOJ4897 题解 发现我们付出的代价与区间长度无关,而与区间权值范围有关 离散化一下权值 我们设\(f[l][r][x][y]\)表示区间\([l,r]\)消到只剩权值在\([x,y] ...

  3. 【bzoj4897】[Thu Summer Camp2016]成绩单 区间dp

    题目描述 给你一个数列,每次你可以选择连续的一段,付出 $a+b\times 极差^2$ 的代价将其删去,剩余部分拼到一起成为新的数列继续进行此操作.求将原序列全部删去需要的最小总代价是多少. 输入 ...

  4. BZOJ 4897: [Thu Summer Camp2016]成绩单 动态规划

    Description 期末考试结束了,班主任L老师要将成绩单分发到每位同学手中.L老师共有n份成绩单,按照编号从1到n的顺序叠 放在桌子上,其中编号为i的成绩单分数为w_i.成绩单是按照批次发放的. ...

  5. BZOJ.4897.[Thu Summer Camp2016]成绩单(区间DP)

    BZOJ 显然是个区间DP.令\(f[l][r]\)表示全部消掉区间\([l,r]\)的最小花费. 因为是可以通过删掉若干子串来删子序列的,所以并不好直接转移.而花费只与最大最小值有关,所以再令\(g ...

  6. 【BZOJ4896】[Thu Summer Camp2016]补退选 Trie树

    [BZOJ4896][Thu Summer Camp2016]补退选 Description X是T大的一名老师,每年他都要教授许多学生基础的C++知识.在T大,每个学生在每学期的开学前都需要选课,每 ...

  7. BZOJ 4896 :[Thu Summer Camp2016]补退选 Trie树+Vector

    4896: [Thu Summer Camp2016]补退选 Time Limit: 20 Sec  Memory Limit: 512 MBSubmit: 315  Solved: 97[Submi ...

  8. BZOJ4896 [Thu Summer Camp2016]补退选 【trie树】

    题目链接 BZOJ4896 题解 \(thu\)怎么那么喜欢出\(trie\)树的题... 我们当然可以按题意模拟建\(trie\) 询问的时候,由于存在删除操作,不满足单调性,不能直接二分答案 我们 ...

  9. BZOJ4896 [Thu Summer Camp2016]补退选

    本文版权归ljh2000和博客园共有,欢迎转载,但须保留此声明,并给出原文链接,谢谢合作. 本文作者:ljh2000 作者博客:http://www.cnblogs.com/ljh2000-jump/ ...

随机推荐

  1. Python函数及参数

    ## 函数 - 函数是代码的一种组织形式,一般一个函数完成一个特定功能 - 函数需要先定义后使用 - 函数的定义 def func_name(参数): func_body ... return fun ...

  2. 解决SecureCRT远程Linux遇到文件不能直接往CRT里直接拖入的问题

    不能拖入到CRT的第一个原因可能是Options-->Global Options-->Terminal中的Mouse下的Copy on select没有勾选.当发现自己勾选了也不能往里面 ...

  3. 数据分析处理库Pandas——merge操作

    有一列列名相同值也相同 有两列列名相同值也相同 按其中一列合并 按两列合并 有一列列名相同值也相同,有一列列名相同值不相同,按两列合并 列名相同值不相同的行删掉 保留所有行 保留所有行并显示合并后该值 ...

  4. python系列2之数据类型

    目录 Python数据类型 python的运算符 Python的循环与判断语句 python练习 Python作业 一.  Python的数据类型 1. 整型(int) <1>.  赋值 ...

  5. https://www.cnblogs.com/gaoxiang12/p/3695962.html

    https://www.cnblogs.com/gaoxiang12/p/3695962.html

  6. python os模块练习题

    # 1.获取某个文件所在目录的上一级目录. # 例如'D:\python\projects\test19.py'目录的结果 :D:\python\projects # 方法1 # path = os. ...

  7. 一步一步学Linq to sql(一):预备知识

    什么是Linq to sql Linq to sql(或者叫DLINQ)是LINQ(.NET语言集成查询)的一部分,全称基于关系数据的 .NET 语言集成查询,用于以对象形式管理关系数据,并提供了丰富 ...

  8. 7.Mongodb安全性流程

    1.安全性流程 2.超级管理员 为了更安全的访问mongodb,需要访问者提供用户名和密码,于是需要在mongodb中创建用户 采用了角色-用户-数据库的安全管理方式 常用系统角色如下: root:只 ...

  9. 2 实现第一个Django网站 博客

    -1.理解上下文 render()渲染 request  url传来的reuqest x.html 制定返回的模板名称 context 上下文    数据库中 替换数据 0.大框架 1.创建模板 (1 ...

  10. Managing WMI security

    TechNet Library TechNet Archive Windows Server 2003 Product Help Windows Server 2003 Product Help Ad ...