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

              斜率优化错误总结

  网上说很多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

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/292427.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

iio Engine logoHTML5 应用框架 iio Engine

iio Engine 是一个新的 HTML5 应用开源框架&#xff0c;基于 JavaScript 和 Canvas 开发&#xff0c;集成了 Box2D 在线演示&#xff1a;http://www.huiyi8.com/divcss/转载于:https://www.cnblogs.com/lhrs/p/4138106.html

带圈汉字 在线生成_手写签名在线生成器-手写签名在线生成器可复制

签名设计地址&#xff1a;www.mgs2s.com&#xff08;复制到浏览器打开&#xff09;工具集成签名设计免费版下载&#xff0c;签名设计免费版在线立即生成&#xff0c;简单简体签名设计免费版。最新方便设计公文签名设计颜色保存分享免费版1、所以大家最好写签名的时候&#xff0…

真快!10秒内将k8s集群运行起来

大家好&#xff0c;我是小碗汤&#xff0c;今天演示一个项目&#xff0c;可以在一分钟内用容器将k8s集群运行起来&#xff0c;真的很方便。您可能已经知道&#xff0c;将 Kubernetes 集群安装在 VM 上。但在 Docker 容器中安装一个 Kubernetes 集群&#xff0c;还没有太多的实践…

上公厕上一半突然被拽出来......

1 哈哈哈哈&#xff0c;太惨了&#xff08;素材来源网络&#xff0c;侵删&#xff09;▼2 糟糕&#xff0c;忘了切换账号了&#xff08;via.豆瓣史上写字最烂小组&#xff09;▼3 南北方酒局区别▼4 奇奇怪怪的东西又增加了&#xff08;素材来源网络&#xff0c;侵删&#x…

context:annotation-config 跟 context:component-scan诠释及区别

<context:annotation-config> 是用于激活那些已经在spring容器里注册过的bean&#xff08;无论是通过xml的方式还是通过package sanning的方式&#xff09;上面的注解。 <context:component-scan>除了具有<context:annotation-config>的功能之外&#xff0c;…

为什么中国这么多高薪程序员,开发不出Java, Typescript, Python, Rust, Node.js这些基础设施?...

近日&#xff0c;有人在网上问了这个问题&#xff0c;引起了网友热议&#xff1a;为什么中国这么多高薪程序员&#xff0c;开发不出Java&#xff0c;Typescript, Python, Rust, Node.js这些基础设施&#xff1f;对这个问题&#xff0c;大家从不同角度发表了自己的看法。有人说&…

当你女朋友第一次来你家会发生什么?

1 五一假期你都怎么过&#xff1f;▼2 万一实现了呢&#xff08;via.月半土荅塔&#xff09;▼3 你下周三就见不到李总了&#xff01;▼4 对不起&#xff0c;但真的很好笑▼5 女朋友第一次来我家做饭▼6 还我美女&#xff01;&#xff01;&#xff01;▼7 走他们的路&…

跟随大数据旅行

2019独角兽企业重金招聘Python工程师标准>>> 跟随大数据旅行 这是一本短小而精悍的书&#xff0c;不需要花费太多时间就能够让读者弄清 楚大数据到底是什么&#xff0c;还能帮助读者了解大数据的来龙去脉以及未来大 数据对各行各业带来的影响与作用。大数据将带来新…

利用for循环调用插入方法批量插入 一条失败_算法与数据结构(1):基础部分——以插入排序为例...

本文将会以插入排序为例&#xff0c;介绍算法与数据结构的基础部分。插入排序排序可以说是整个算法中最为基础&#xff0c;最为重要的一部分&#xff0c;而插入排序正是排序算法中最简单的一种解决办法。什么是排序问题&#xff1f;输入&#xff1a;n个数的一个序列 。输出&…

MindFusion Pack for ASP.NET发布v2013.R2

在MindFusion.Diagramming for WebForms中&#xff1a;导入OpenOffice Draw文件新的DrawImporter类允许你通过OpenOffice Draw Vector图形编辑器导入后缀为*.odg的文件。只需添加一个引用到MindFusion.Diagramming.Import.Draw.dll组即可。你还可以使用导入法的多种重载将OpenO…

【翻译】C#表达式中的动态查询

当您使用LINQ来处理数据库时&#xff0c;这种体验是一种神奇的体验&#xff0c;对吗&#xff1f;你把数据库实体像一个普通的收集&#xff0c;使用Linq中像Where&#xff0c;Select或者 Take&#xff0c;这些简单的使用就能让代码可用了。但是&#xff0c;让我们考虑一下这里是…

SVD++:推荐系统的基于矩阵分解的协同过滤算法的提高

1.背景知识 在讲SVD之前&#xff0c;我还是想先回到基于物品相似的协同过滤算法。这个算法基本思想是找出一个用户有过正反馈的物品的相似的物品来给其作为推荐。其公式为&#xff1a; 其中 rui 表示预测用户u对物品i的喜爱程度。wij 是物品i&#xff0c;j之间的相似度&#xf…

Android插件化开发之动态加载的类型

https://segmentfault.com/a/1190000005113493 基本信息 Author&#xff1a;kaedea GitHub&#xff1a;android-dynamical-loading 现在网络上有许多关于动态加载的介绍的文章&#xff0c;谈及的关键词汇有动态加载、插件化、热部署、热修复等&#xff0c;对于一些刚接触这方…

UITableView的优化原理

2019独角兽企业重金招聘Python工程师标准>>> 当我们下啦一个 UITableView时&#xff0c;如果没有做优化&#xff0c;只是简单的实现功能代码如下&#xff0c;这样当我们有上百条tableviewcell的时候&#xff0c;我们滑动的非常快时会非常费内存&#xff0c;当然苹果…

深入浅出Mybatis系列(一)---Mybatis入门[转]

最近两年 springmvc mybatis 的在这种搭配还是蛮火的&#xff0c;楼主我呢&#xff0c;也从来没真正去接触过mybatis, 趁近日得闲&#xff0c; 就去学习一下mybatis吧。 本次拟根据自己的学习进度&#xff0c;做一次关于mybatis 的一系列教程&#xff0c; 记录自己的学习历程&…

C# 图像模板匹配并标注

01—需求这个是粉丝在我的技术群提的一个需求1、 模板匹配 &#xff1a;功能&#xff1a;&#xff08;1&#xff09;在一张大图像中&#xff0c;选取一小块区域作为模板&#xff08;2&#xff09;可在大图像中匹配到模板图像和位置。模板匹配是图像处理中最基本、最常用的匹配方…

深入浅出Mybatis系列(八)---mapper映射文件配置之select、resultMap[转]

上篇《深入浅出Mybatis系列&#xff08;七&#xff09;---mapper映射文件配置之insert、update、delete》介绍了insert、update、delete的用法&#xff0c;本篇将介绍select、resultMap的用法。select无疑是我们最常用&#xff0c;也是最复杂的&#xff0c;mybatis通过resultMa…