斜率优化错误总结

  网上说很多OJ桑的斜率优化大多都是模板题- -,结果每次都跪Orz。。。在此总结一些常见错误:

  1:不得不说斜率优化很多时候计算式很长- -,代码容易错细节- -。

  2:其次就是弹队头以及弹队尾的时候大小关系容易错,关键是除负数时要变号,

       弹的时候边界要弄好,总的来说很多斜率优化都很像:推式子——>边弹边做边入队;

  3:再者就是一些先后问题:

    在处理队列的时候,尤其是弹队尾的时候,如果有推导式中有未知量要先计算,不然会弹WA- -;

  4:还有队列初始化问题- -要机智点- -;

  

  代码:

    1:锯木厂选址(CEOI2004试题)

 1 #include<cstdio>
 2 int n,f=1,r,top=1,tai=1,ans=888888888,c[20010],w[20010],d[20010],s[20010];
 3 int  all(int a,int b){return c[b]-c[a]-w[a-1]*(d[b]-d[a]); }
 4 double k(int a,int b){return (double)(w[a]*d[a]-w[b]*d[b])/(double)(w[a]-w[b]);}
 5 int main(){
 6     scanf("%d",&n);    s[1]=1;
 7     for (int i=1; i<=n  ; i++) scanf("%d%d",&w[i],&d[i+1]);
 8     for (int i=2; i<=n+1; i++) w[i] += w[i-1];
 9     for (int i=2; i<=n+1; i++) c[i]  = c[i-1]+w[i-1]*d[i] ;
10     for (int i=2; i<=n+1; i++) d[i] += d[i-1];
11     for (int i=2; i<=n; i++){
12         while (top< tai&&k(s[top],s[top+1])<=  d[ i ]   ) top++;
13         while (top<=tai&&k(s[tai-1],s[tai])>=k(s[tai],i)) tai--;
14         r = c[ s[top] ] + all(s[top]+1,i) + all(i+1,n+1);
15         if (r<ans) ans=r; s[++tai]=i;
16     }   printf("%d",ans);
17 }

锯木厂选址(CEOI2004)

    2:玩具装箱  (HNOI2008试题)

 1 #include<cstdio>
 2 long long top=0,tai=0,s[50010],f[50010],n,l,K,h[50010];
 3 long double k(int a,int b) {
 4     return (long double)(f[b]+h[b]*h[b]-f[a]-h[a]*h[a])
 5           /(long double)(h[b]-h[a]);
 6 }
 7 int main(){
 8     scanf("%lld%lld",&n,&l);
 9     for (int i=1; i<=n; i++) scanf("%lld",&h[i]);
10     for (int i=1; i<=n; i++) h[i]+=h[i-1]+1;
11     for (int i=1; i<=n; i++) {
12         K=h[i]-1-l;
13         while (top< tai&&k(s[top],s[top+1])<=2*K) top++;
14         f[i]=f[s[top]]+(K-h[s[top]])*(K-h[s[top]]);
15         while (top<=tai&&k(s[tai-1],s[tai])>=k(s[tai],i)) tai--;
16         s[++tai]=i;
17     }   printf("%lld",f[n]);
18 }

玩具装箱  (HNOI2008)

    3:土地并购  (USACO精选49)

 1 #include<cstdio>
 2 #include<algorithm>
 3 struct p{long long a,b;}t[50010];
 4 long long l,n,top=0,tai=0,f[50010],s[50010];
 5 bool cmp(const p&x,const p&y) {return (x.a<y.a)||(x.a==y.a&&x.b<y.b);}
 6 long double k(long long j1,long long j2 )  {
 7     return (long double)(f[j1]-f[j2])/
 8            (long double)(t[j2+1].b-t[j1+1].b);
 9 }
10 int main(){
11     scanf("%lld",&n);
12     for (int i=1; i<=n; i++) scanf("%lld%lld",&t[i].a,&t[i].b);
13     std::sort(t+1,t+n+1,cmp);
14     for (int i=1; i<=n; i++) {
15         while (l&&t[i].b>=t[l].b) l--;
16         t[++l].a=t[i].a;
17         t[  l].b=t[i].b;
18     }
19     for (int i=1; i<=l; i++) {
20         while (top< tai&&k(s[top],s[top+1])<=  t[ i ].a ) top++;
21         f[i]=f[s[top]]+t[i].a*t[s[top]+1].b;
22         while (top<=tai&&k(s[tai-1],s[tai])>=k(s[tai],i)) tai--;
23         s[++tai]=i;
24     }   printf("%lld",f[l]);
25 }

土地并购(USACO精选49)

转载于:https://www.cnblogs.com/qq359084415/p/3435350.html

关于最近打的几题斜率优化的总结。加几AC代码。相关推荐

  1. HDU 2993 MAX Average Problem(斜率优化DP)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2993 题目大意:给定一个长度为n(最长为10^5)的正整数序列,求出连续的最短为k的子序列平均值的最大 ...

  2. [Comet OJ - Contest #7 D][52D 2417]机器学习题_斜率优化dp

    机器学习题 题目大意: 数据范围: 题解: 学长说是决策单调性? 直接斜率优化就好了嘛 首先发现的是,$A$和$B$的值必定是某两个$x$值. 那么我们就把,$y$的正负分成两个序列,$val1_i$ ...

  3. 斜率优化 Snowdrop修长廊 scu dp练习B题

    传送门:点击打开链接 题意:要覆盖完n个点,要覆盖掉[i,j]的代价是(X[i]-X[j])*(X[i]-X[j])+W,求覆盖完所有点的最小代价 思路:这是一道非常裸的斜率优化. 网上讲解斜率优化的 ...

  4. 【BZOJ3963】[WF2011]MachineWorks cdq分治+斜率优化

    [BZOJ3963][WF2011]MachineWorks Description 你是任意性复杂机器公司(Arbitrarily Complex Machines, ACM)的经理,公司使用更加先 ...

  5. 【洛谷3648】[APIO2014] 序列分割(斜率优化DP)

    点此看题面 大致题意: 你可以对一个序列进行\(k\)次分割,每次得分为两个块元素和的乘积,求总得分的最大值. 区间\(DPor\)斜率优化\(DP\) 这题目第一眼看上去感觉很明显是区间\(DP\) ...

  6. 【BZOJ1010】【HNOI2008】玩具装箱(斜率优化,动态规划)

    [BZOJ1010][HNOI2008]玩具装箱 题面 题目描述 P教授要去看奥运,但是他舍不下他的玩具,于是他决定把所有的玩具运到北京.他使用自己的压缩器进行压缩,其可以将任意物品变成一堆,再放到一 ...

  7. 【学习笔记】斜率优化

    [学习笔记]斜率优化 [SDOI2012]任务安排 斜率优化入门题: 设\(f(x)\)为\(F(x)\)的后缀和,\(t(x)\)为\(T(x)\)的前缀和.\(dp(i)\)表示完成到第\(i\) ...

  8. APIO2010 特别行动队 斜率优化DP算法笔记

    做完此题之后 自己应该算是真正理解了斜率优化DP 根据状态转移方程$f[i]=max(f[j]+ax^2+bx+c),x=sum[i]-sum[j]$ 可以变形为 $f[i]=max((a*sum[j ...

  9. luogu P5468 [NOI2019]回家路线 (斜率优化、DP)

    题目链接: (luogu) https://www.luogu.org/problemnew/show/P5468 题解: 爆long long毁一生 我太菜了,这题这么简单考场上居然没想到正解-- ...

最新文章

  1. 黑盒测试之两两组合方法
  2. Software development Problem
  3. php人气代码,php – 人气算法
  4. 定位技术GPS/A-GPS/LBS/WIFI定位介绍
  5. labview与下位机通信的格式问题处理
  6. 生成和合入patch的两种方式
  7. android ascii 比较大小写,为什么可以通过ASCII中的字母排序规则来进行字母的大小写转换?...
  8. Go语言 -- PostgreSQL数据库
  9. junit单元测试步骤
  10. Python + Opencv 实现遥感影像tif格式转jpg
  11. macOS中使用Delete键
  12. java英语apple_apple是什么意思_apple在线翻译_英语_读音_用法_例句_海词词典
  13. 区块链钱包—BTC Java版离线签名交易
  14. 链表的有序集合(java)
  15. 2023华中农业大学计算机考研信息汇总
  16. arm交叉编译器下载
  17. js 天花板 playcanvas
  18. Mysql 查询数据库中哪个表的字段个数最多
  19. 2023年中南财经政法大学西方经济学考研上岸前辈初复试备考经验
  20. ST32/GD32嵌入式硬件开发总目录

热门文章

  1. bzoj 1911: [Apio2010]特别行动队 2011-12-26
  2. tab标签的另一种写法
  3. linux系统的运行定义在,Linux系统运行级管理
  4. centos镜像 from_【CentOS 7.1】使用163的镜像
  5. 新字符设备驱动实验(自动分配设备号、自动创建应用层设备节点、新字符设备注册到内核的结构体)
  6. 什么是字节码,采用字节码的好处是什么
  7. css改变指针形状,css 指针样式
  8. 一个本地分支能关联两个远程仓库吗_使用git分支保存hexo博客源码到github
  9. 盘点 20多种基本Java库和API,值得收藏!
  10. 60度斜坡怎么计算_【测绘】南方CASS土方计算方法—方格网法