http://www.lydsy.com/JudgeOnline/problem.php?id=2448

一遍过,嘎嘎嘎嘎嘎嘎嘎嘎嘎嘎嘎嘎,O(∩_∩)O~

题意是最小化最大值

设计区间dp

dp[i][j] 表示在能确定x不在区间[i,j]内,或确定x在区间[i,j]内某个位置的最坏情况下的最小值

dp[i][j]=min { max(dp[i][k-1],dp[k+1][j] ) + a[k] }  k∈[i,j]

O(n^3)复杂度

#include<cstdio>
#include<cstring>
#include<iostream> using namespace std; #define N 2002 int a[N]; int dp[N][N]; void read(int &x)
{
x=; char c=getchar();
while(!isdigit(c)) c=getchar();
while(isdigit(c)) { x=x*+c-''; c=getchar(); }
} int main()
{
int n;
read(n);
for(int i=;i<=n;++i) read(a[i]);
memset(dp,,sizeof(dp));
for(int i=;i<=n;++i)
dp[i][i]=a[i],dp[i][i-]=;
for(int i=n;i;--i)
for(int j=i;j<=n;++j)
for(int k=i;k<=j;++k)
dp[i][j]=min(dp[i][j],max(dp[i][k-],dp[k+][j])+a[k]);
printf("%d",dp[][n]);
}

优化:

把max去掉,就可以使用单调队列优化了

很显然的结论是长区间的dp值一定>=它的子区间的dp值

当固定i和j时,随着k的递增,dp[i][k-1]单调不降,dp[k+1][j]单调不增

所以一定可以找到一个分界点g,

当k∈[i,g]时,dp[i][k-1]>dp[k+1][j]

当k∈[g+1,j]时,dp[k+1][j]>dp[i][k-1]

所以上述转移方程变为

当k∈[i,g]时,dp[i][j]=min { dp[i][k-1]+a[k] }

当k∈[g+1,j]时,dp[i][j]=min { dp[k+1][j]+a[k] }

用g[i][j]表示对于每对i,j 求出的g

对于 当k∈[i,g[i][j] ]时,dp[i][j]=min { dp[i][k-1]+a[k] }

可以得出结论 g[a][b]<=g[a][b+1]

因为这里是前面的dp值>后面的dp值,[a,b+1]在[a,b]后面加了一个位置,

后面的dp值不变或增大,前面要包含更多的位置使前面变的更大,才能>=后面,所以g的位置不变或后移

所以固定区间左端点,随右端点的右移,g单调不减

对于 当k∈[g[i][j]+1,j]时,dp[i][j]=min { dp[k+1][j]+a[k] }

可以得出结论 g[a-1][b]<=g[a][b]

因为这里是后面的dp值>前面的dp值,[a-1,b]在[a,b]前面加了一个一个位置

前面的dp值不变或增大,后面要包含更多的位置使后面变的更大,才能>=前面,所以g的位置不变或前移

所以固定区间右端点,随左端点的左移,g单调不增

所以可维护n+1个单调队列

一个表示固定左端点,n个表示固定右端点

因为是左端点从n倒序枚举,右端点从左端点正序枚举

所以固定左端点的只需要用一个,左端点改变的时候清空队列即可

但是右端点是跳来跳去的,所以要用n个

实际实现的时候可以不计算g

如果要计算g的话,由上面可以得出结论

g[a-1][b]<=g[a][b]<=g[a][b+1]

利用g的单调性计算g

#include<cstdio>
#include<cstring>
#include<iostream>
#include<algorithm> using namespace std; #define N 2002 int a[N]; int dp[N][N]; int q[N][N];
int h[N],t[N]; #define A(x) dp[i][(x)-1]+a[(x)]
#define B(x) dp[(x)+1][j]+a[(x)] void read(int &x)
{
x=; char c=getchar();
while(!isdigit(c)) c=getchar();
while(isdigit(c)) { x=x*+c-''; c=getchar(); }
} int main()
{
int n;
read(n);
for(int i=;i<=n;++i) read(a[i]);
memset(dp,,sizeof(dp));
for(int i=n;i;--i)
{
dp[i][i]=a[i];
h[]=;
q[][t[]=]=i;
q[i][t[i]=]=i;
for(int j=i+;j<=n;++j)
{
while(h[]<t[] && A(q[][h[]])<B(q[][h[]])) ++h[];
while(h[]<t[] && A(j)<A(q[][t[]-])) --t[];
q[][t[]++]=j;
while(h[j]<t[j] && B(q[j][h[j]])<A(q[j][h[j]])) ++h[j];
while(h[j]<t[j] && B(i)<B(q[j][t[j]-])) --t[j];
q[j][t[j]++]=i;
dp[i][j]=min(A(q[][h[]]),B(q[j][h[j]]));
}
}
printf("%d",dp[][n]);
}

2448: 挖油

Time Limit: 10 Sec  Memory Limit: 128 MB
Submit: 133  Solved: 57
[Submit][Status][Discuss]

Description

给出一条线段,在左端点点0与右端点n+1间有n个点(n<=2000),并且在0到x之间的所有点都是有油的,在每个点钻井判断是否有油需要时间ti,求能够知道x的最坏情况下最少需要多少时间。
 

Input

第一行包含一个数n,如题目描述。
第二行包含n个数,表示在第i个点钻井判断是否有油需要的时间。
 

Output

输出包含一行,最坏情况下最少需要多少时间。
 

Sample Input

4
8 24 12 6

Sample Output

42

HINT

对于100%的数据,n<=2000,ti<=10^6

bzoj千题计划235:bzoj2448: 挖油的更多相关文章

  1. bzoj千题计划300:bzoj4823: [Cqoi2017]老C的方块

    http://www.lydsy.com/JudgeOnline/problem.php?id=4823 讨厌的形状就是四联通图 且左右各连一个方块 那么破坏所有满足条件的四联通就好了 按上图方式染色 ...

  2. bzoj千题计划196:bzoj4826: [Hnoi2017]影魔

    http://www.lydsy.com/JudgeOnline/problem.php?id=4826 吐槽一下bzoj这道题的排版是真丑... 我还是粘洛谷的题面吧... 提供p1的攻击力:i,j ...

  3. bzoj千题计划280:bzoj4592: [Shoi2015]脑洞治疗仪

    http://www.lydsy.com/JudgeOnline/problem.php?id=4592 注意操作1 先挖再补,就是补的范围可以包含挖的范围 SHOI2015 的题 略水啊(逃) #i ...

  4. bzoj千题计划177:bzoj1858: [Scoi2010]序列操作

    http://www.lydsy.com/JudgeOnline/problem.php?id=1858 2018 自己写的第1题,一遍过 ^_^ 元旦快乐 #include<cstdio> ...

  5. bzoj千题计划317:bzoj4650: [Noi2016]优秀的拆分(后缀数组+差分)

    https://www.lydsy.com/JudgeOnline/problem.php?id=4650 如果能够预处理出 suf[i] 以i结尾的形式为AA的子串个数 pre[i] 以i开头的形式 ...

  6. bzoj千题计划304:bzoj3676: [Apio2014]回文串(回文自动机)

    https://www.lydsy.com/JudgeOnline/problem.php?id=3676 回文自动机模板题 4年前的APIO如今竟沦为模板,,,╮(╯▽╰)╭,唉 #include& ...

  7. bzoj千题计划292:bzoj2244: [SDOI2011]拦截导弹

    http://www.lydsy.com/JudgeOnline/problem.php?id=2244 每枚导弹成功拦截的概率 = 包含它的最长上升子序列个数/最长上升子序列总个数 pre_len ...

  8. bzoj千题计划278:bzoj4590: [Shoi2015]自动刷题机

    http://www.lydsy.com/JudgeOnline/problem.php?id=4590 二分 这么道水题 没long long WA了两发,没判-1WA了一发,二分写错WA了一发 最 ...

  9. bzoj千题计划250:bzoj3670: [Noi2014]动物园

    http://www.lydsy.com/JudgeOnline/problem.php?id=3670 法一:KMP+st表 抽离nxt数组,构成一棵树 若nxt[i]=j,则i作为j的子节点 那么 ...

随机推荐

  1. Github相册博客搭建

    前一段时间我看见一个问答,大概意思就是程序员都是怎么用自己的专业技能逗女朋友或表白的. 看了很多,有写定时关机脚本恶搞的,也有简单写个html展示的,其中最著名的就是几年前有个人写了个网页记录他们在一 ...

  2. Appium+python自动化4-元素定位uiautomatorviewer

    前言 环境搭建好了,下一步元素定位,元素定位本篇主要介绍如何使用uiautomatorviewer,通过定位到页面上的元素,然后进行相应的点击等操作. uiautomatorviewer是androi ...

  3. 树形DP ---- Codeforces Global Round 2 F. Niyaz and Small Degrees引发的一场血案

    Aspirations:没有结果,没有成绩,acm是否有意义?它最大的意义就是让我培养快速理解和应用一个个未知知识点的能力. ————————————————————————————————————— ...

  4. 学习 google file system 心得体会

    Google File system文件系统,是在特别便宜的普通硬件设备上运行,它是一个面向大规模数据密集型运用的.可伸缩的分布式文件系统. 与传统文件相比,它认为组件失效是很平常的事件,因为GFS包 ...

  5. someday团队Postmortem(事后诸葛亮会议)

    一.会议相关介绍: 时间:2018年1月12日 地点:第九实验楼五楼机房 参会人员:someday团队全体成员 二.每个成员在beta阶段的实践和alpha阶段有何改进? (一)设想和目标: 我们的软 ...

  6. 软件工程实践-git的使用

    ² Github使用心得 其实以前就注册过一个github账号,不过那时只不过是因为在网上看到这个挺对于程序员有着重大作用就顺手去弄了,从未使用过,直到这次软工实践需要我才从新回想起来. 之前的几篇随 ...

  7. 回忆--RYU流量监控

    RYU流量监控 前言 Ryu book上的一个流量监控的应用,相对比较好看懂 实验代码 github源码 from ryu.app import simple_switch_13 from ryu.c ...

  8. 动态规划刷题集python代码

    1 爬楼梯(Fibonacci) #有一楼梯共M级,若每次只能跨上一级或二级,要走上第M级,共有多少种走法? def fun(m): c = [0]*m c[0] = 1 c[1] = 2 for i ...

  9. order by null 的作用

    在SQL中order by null有什么用吗?这是我在一次面试时面试官问我的问题,当时我是懵的.他让我猜一下,我说不排序?没想到被我猜对了 不排序你就别用order by啊!为什么要用order b ...

  10. [转帖]Edge投降Chromium!微软王牌浏览器是如何跪倒的

    Edge投降Chromium!微软王牌浏览器是如何跪倒的   https://tech.sina.com.cn/n/k/2018-12-17/doc-ihmutuec9824604.shtml   谷 ...