小P的牧场
【题目描述】
背景:小P 是个特么喜欢玩MC 的孩纸。。。
小P 在MC 里有n 个牧场,自西向东呈一字形排列(自西向东用1…n 编号),于是他就烦恼了:为了控制这n 个牧场,他需要在某些牧场上面建立控制站,每个牧场上只能建立一个控制站,每个控制站控制的牧场是它所在的牧场一直到它西边第一个控制站的所有牧场(它西边第一个控制站所在的牧场不被控制)(如果它西边不存在控制站,那么它控制西边所有的牧场),每个牧场被控制都需要一定的花费(毕竟在控制站到牧场间修建道路是需要资源的嘛~),而且该花费等于它到控制它的控制站之间的牧场数目(不包括自身,但包括控制站所在牧场)乘上该牧场的放养量,在第i 个牧场建立控制站的花费是ai,每个牧场i 的放养量是bi,理所当然,小P 需要总花费最小,但是小P的智商有点不够用了,所以这个最小总花费就由你来算出啦。
【输入格式】
第一行一个整数n 表示牧场数目
第二行包括n 个整数,第i 个整数表示ai
第三行包括n 个整数,第i 个整数表示bi
【输出格式】
只有一行,包括一个整数,表示最小花费
【样例输入】
4
2 4 2 4
3 1 4 2
【样例输出】
9
【样例解释】
选取牧场1,3,4 建立控制站,最小费用为2+( 2 + 1 * 1 ) + 4 = 9。
数据范围与约定
对于10%的数据,1 <= n <= 10
对于30%的数据,1 <= n <= 1000
对于100%的数据,1 <= n <= 1000000 , 0 < ai,bi <= 10000

分析:

经过思考可以得到这样一个式子

f[i,1]表示在第i个牧场建站且右边的牧场已全部控制的最小费用,f[i,0]表示第i个牧场未建站而从i到n的牧场都被控制的最小代价,倒着来进行处理。

f[i,1]:=min(f[i+1,1],f[i+1,0])+a[i];

f[i,0]:=min(f[j,1]+t); (i:=n..1,i<j<n)

其中t表示i..j-1的牧场被j控制的总代价,在动规循环同时求出,这样要用三层循环,显然这个效率并不好。

对DP进行改进,将牧场排列倒过来,同时改进f,f[i]表示在第i个牧场建站并之前的牧场都被控制的最小总代价,我们增加一个牧场n+1,令其建站和被控制代价为0。则有:

f[i]:=min(f[j]+t)+a[i];(i:=1..n+1,1<=j<i) 其中t表示j+1..i-1的牧场都被控制的总代价,求t可以采用一个很好地方法:

令s[i]表示1..i的a数组元素和,u[i]表示1..i的s数组元素和:

t=s[i-1]-s[j]+s[i-1]-s[j+1]+...+s[i-1]-s[i-2]

=s[i-1]*(i-j-1)-(s[j]+s[j+1]+s[j+2]+..+s[i-2])

=s[i-1]*(i-j-1)-(u[i-2]-u[j-1])

于是得到:

f[i]:=min(f[j]+s[i-1]*(i-j-1)-(u[i-2]-u[j-1]))+a[i];

时间效率为O(n^2),这样还不够,于是进行斜率优化,要注意向队列添加元素时队内最少元素数目不低于2个,我就在这里处理错了导致之前一直没AC。

代码:

  1. program pasture;
  2. var
  3. f:array[..]of int64;
  4. a,b,u,s,q:array[..]of int64;
  5. n,m,t,k,h,j:int64; i:longint;
  6. function min(x,y:int64):int64;
  7. begin
  8. if x<y then min:=x else min:=y;
  9. end;
  10. function cal1(x,y:longint):int64;
  11. begin
  12. exit(f[x]-f[y]+u[x-]-u[y-]);
  13. end;
  14. function cal2(x,y:longint):int64;
  15. begin
  16. exit(x-y);
  17. end;
  18. begin
  19. readln(n);
  20. for i:=n downto do
  21. read(a[i]);
  22. readln;
  23. for i:=n downto do
  24. read(b[i]);
  25. for i:= to n do
  26. s[i]:=s[i-]+b[i];
  27. for i:= to n do
  28. u[i]:=u[i-]+s[i];
  29. f[]:=a[]; q[]:=; h:=; t:=;
  30. for i:= to n+ do
  31. begin
  32. while (h<t)and(cal1(q[h+],q[h])<s[i-]*cal2(q[h+],q[h])) do inc(h);
  33. j:=q[h];
  34. f[i]:=f[j]+s[i-]*(i-j-)-(u[i-]-u[j-])+a[i];
  35. while (t-h>=)and(cal1(i,q[t])*cal2(q[t],q[t-])<=cal1(q[t],q[t-])*cal2(i,q[t])) do dec(t);
  36. t:=t+; q[t]:=i;
  37. end;
  38. writeln(f[n+]);
  39. end.

BZOJ 3437:小P的牧场(DP+斜率优化)的更多相关文章

  1. BZOJ 3437 小P的牧场(斜率优化DP)

    [题目链接] http://www.lydsy.com/JudgeOnline/problem.php?id=3437 [题目大意] n个牧场排成一行,需要在某些牧场上面建立控制站, 每个牧场上只能建 ...

  2. bzoj 3437: 小P的牧场【斜率优化】

    emmm妹想到要倒着推 先假设只在n建一个控制站,这样的费用是\( \sum_{i=1}^{n} b[i]*(n-i) \)的 然后设f[i]为在i到n键控制站,并且i一定建一个,能最多节省下的费用, ...

  3. 【BZOJ-3437】小P的牧场 DP + 斜率优化

    3437: 小P的牧场 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 705  Solved: 404[Submit][Status][Discuss ...

  4. BZOJ 3437: 小P的牧场 斜率优化DP

    3437: 小P的牧场 Description 背景 小P是个特么喜欢玩MC的孩纸... 描述 小P在MC里有n个牧场,自西向东呈一字形排列(自西向东用1…n编号),于是他就烦恼了:为了控制这n个牧场 ...

  5. bzoj 3437: 小P的牧场 -- 斜率优化

    3437: 小P的牧场 Time Limit: 10 Sec  Memory Limit: 128 MB Description 小P在MC里有n个牧场,自西向东呈一字形排列(自西向东用1…n编号), ...

  6. bzoj3437 小P的牧场(斜率优化dp)

    3437: 小P的牧场 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 2025  Solved: 1110[Submit][Status][Discu ...

  7. BZOJ3437 小P的牧场 【斜率优化dp】

    3437: 小P的牧场 Time Limit: 10 Sec  Memory Limit: 128 MB Submit: 1502  Solved: 836 [Submit][Status][Disc ...

  8. BZOJ 3437: 小P的牧场

    传送门 显然考虑 $dp$,设 $f[i]$ 表示前 $i$ 个牧场都被控制的最小代价 那么枚举所有 $j<i$ ,$f[i]=f[j]+val[i][j]+A[i]$ $val[i][j]$ ...

  9. BZOJ 1010: [HNOI2008]玩具装箱toy [DP 斜率优化]

    1010: [HNOI2008]玩具装箱toy Time Limit: 1 Sec  Memory Limit: 162 MBSubmit: 9812  Solved: 3978[Submit][St ...

  10. BZOJ 1911: [Apio2010]特别行动队( dp + 斜率优化 )

    sum为战斗力的前缀和 dp(x) = max( dp(p)+A*(sumx-sump)2+B*(sumx-sump)+C )(0≤p<x) 然后斜率优化...懒得写下去了... ------- ...

随机推荐

  1. World Wind Java开发之六——解析shape文件(转)

    http://blog.csdn.net/giser_whu/article/details/41647117 最近一直忙于导师项目的事情了,几天没更新了,昨天和今天研究了下WWJ解析shp文件的源代 ...

  2. Unix系统中常用的信号含义

    http://blog.csdn.net/u012349696/article/details/50687462 编号为1 ~ 31的信号为传统UNIX支持的信号,是不可靠信号(非实时的),编号为32 ...

  3. 重学css3(概览)

    css3新特性概览: 1.强大的选择器 2.半透明度效果的实现 3.多栏布局 4.多背景图 5.文字阴影 6.开放字体类型 7.圆角 8.边框图片 9.盒子阴影 10.媒体查询 浏览器内核又可以分成两 ...

  4. 查看电脑是否安装node.js

    打开命令行

  5. 常用的ES6语法

    1. let.const 和 block 作用域 let 允许创建块级作用域,ES6 推荐在函数中使用 let 定义变量,而非 var: var a = 2; { let a = 3; console ...

  6. SVN不显示状态图标

    1,输入win+R,输入regedit,调出注册表信息 2,按下Ctrl+F,在注册表里搜索“ShellIconOverlayIdentifiers” 3,将TortoiseAdded.Tortois ...

  7. django-redis缓存记录

    对于站点缓存,我们使用redis这款key-value数据库.Redis有着更为复杂的数据结构并且提供对他们的原子性操作,这是一个不同于其他数据库的进化路径.Redis的数据类型都是基于基本数据结构的 ...

  8. kubernetes搭建dashboard-v1.10.1

    一键部署脚本(或者可使用helm安装): wget https://raw.githubusercontent.com/kubernetes/dashboard/v1.10.1/src/deploy/ ...

  9. .net core IdentityServer4 使用query参数

    基本用法请参考官方文档:https://identityserver4.readthedocs.io/en/latest/index.html 这里不对具体用法进行说明,一般情况下,Startup添加 ...

  10. js跨域及解决办法

    1.什么是跨域 我们经常会在页面上使用ajax请求访问其他服务器的数据,此时,客户端会出现跨域问题. 跨域问题是由于javascript语言安全限制中的同源策略造成的. 简单来说,同源策略是指一段脚本 ...