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

https://www.luogu.org/problemnew/show/P2900

约翰准备扩大他的农场,眼前他正在考虑购买N块长方形的土地。如果约翰单买一块土 地,价格就是土地的面积。但他可以选择并购一组土地,并购的价格为这些土地中最大的长 乘以最大的宽。比如约翰并购一块3 × 5和一块5 × 3的土地,他只需要支付5 × 5 = 25元, 比单买合算。 约翰希望买下所有的土地。他发现,将这些土地分成不同的小组来并购可以节省经费。 给定每份土地的尺寸,请你帮助他计算购买所有土地所需的最小费用。

为了写模拟赛的代码现学了斜率优化。

我们显然对于所有的土地按照长宽为第一、第二关键字降序排序,这样的话我们发现对于一块土地,要么它和它前面的土地捆绑买,要么和它后面的土地捆绑买,除此之外的买法显然不优。

那这样我们显然有一个O(n^2)的转移,接下来我们考虑优化。

我们要想优化dp,显然要有单调性,考虑到当一块土地的l和w都小于其它一些土地时它只能被捆绑买且对答案没有贡献,那么我们就可以删掉这些点。

那么剩下的点显然满足l单调降w单调升,于是先列出转移方程f[i]=min(f[k]+l[k+1]*w[i])。

考虑当k<j<i时,如果f[k]+l[k+1]*w[i]>f[j]+l[j+1]*w[i],那么显然j的状态是更优的,我们就可以把小的k踢出去。

将该式子可化为g[k,j]=(f[k]-f[j])/(l[j+1]-l[k+1])>w[i],于是我们有了一种判断当前状态是否需要被踢出的方法。

那么我们开一个单调队列,它的头就可以用这个方式维护。

至于它的尾,考虑当k<j<i时我们可以通过g[k,j]<g[j,i]来踢出j。

为什么?考虑如果g[j,i]>w我们就可以把j踢出。

如果g[k,j]<g[j,i]<w时那么显然k比j优,所以我们还可以把j踢出。

于是我们就能处理尾部了。

那么剩下的就很显然了,只有头指针代表的元素才是最优的,那么只从头处转移即可。

  1. #include<iostream>
  2. #include<cstring>
  3. #include<cstdio>
  4. #include<cmath>
  5. #include<algorithm>
  6. using namespace std;
  7. typedef long long ll;
  8. const int N=;
  9. inline int read(){
  10. int X=,w=;char ch=;
  11. while(ch<''||ch>''){if(ch=='-')w=-;ch=getchar();}
  12. while(ch>=''&&ch<='')X=(X<<)+(X<<)+ch-'',ch=getchar();
  13. return X*w;
  14. }
  15. struct buy{
  16. ll l,w;
  17. }a[N],b[N];
  18. bool cmp(buy a,buy b){
  19. return a.l>b.l||(a.l==b.l&&a.w>b.w);
  20. }
  21. int n,cnt,l,r,maxw;
  22. ll f[N],q[N];
  23. inline double suan(int j,int k){
  24. return 1.0*(f[j]-f[k])/(b[k+].l-b[j+].l);
  25. }
  26. int main(){
  27. n=read();
  28. for(int i=;i<=n;i++)
  29. a[i].l=read(),a[i].w=read();
  30. sort(a+,a+n+,cmp);
  31. for(int i=;i<=n;i++){
  32. if(a[i].w>maxw){
  33. maxw=a[i].w;
  34. b[++cnt]=a[i];
  35. }
  36. }
  37. for(int i=;i<=cnt;i++){
  38. while(l<r&&suan(q[l],q[l+])<(double)b[i].w)l++;
  39. f[i]=f[q[l]]+b[q[l]+].l*b[i].w;
  40. while(l<r&&suan(q[r],i)<suan(q[r-],q[r]))r--;
  41. q[++r]=i;
  42. }
  43. printf("%lld\n",f[cnt]);
  44. return ;
  45. }

+++++++++++++++++++++++++++++++++++++++++++

+本文作者:luyouqi233。               +

+欢迎访问我的博客:http://www.cnblogs.com/luyouqi233/+

+++++++++++++++++++++++++++++++++++++++++++

BZOJ1597 & 洛谷2900:[USACO2008 MAR]Land Acquisition 土地购买——题解的更多相关文章

  1. 洛谷2900 [USACO08MAR]土地征用Land Acquisition (斜率优化+dp)

    自闭的一批....为什么斜率优化能这么自闭. 首先看到这个题的第一想法一定是按照一个维度进行排序. 那我们不妨直接按照\(h_i\)排序. 我们令\(dp[i]\)表示到了第\(i\)个矩形的答案是多 ...

  2. 洛谷P2900 [USACO08MAR]土地征用Land Acquisition(动态规划,斜率优化,决策单调性,线性规划,单调队列)

    洛谷题目传送门 用两种不一样的思路立体地理解斜率优化,你值得拥有. 题意分析 既然所有的土地都要买,那么我们可以考虑到,如果一块土地的宽和高(其实是蒟蒻把长方形立在了平面上)都比另一块要小,那么肯定是 ...

  3. 洛谷 P2900 [USACO08MAR]土地征用Land Acquisition 解题报告

    P2900 [USACO08MAR]土地征用Land Acquisition 题目描述 约翰准备扩大他的农场,眼前他正在考虑购买N块长方形的土地.如果约翰单买一块土 地,价格就是土地的面积.但他可以选 ...

  4. 洛谷P2900 [USACO08MAR]土地征用Land Acquisition(斜率优化)

    题意 约翰准备扩大他的农场,眼前他正在考虑购买N块长方形的土地.如果约翰单买一块土 地,价格就是土地的面积.但他可以选择并购一组土地,并购的价格为这些土地中最大的长 乘以最大的宽.比如约翰并购一块3 ...

  5. 【洛谷P3369】【模板】普通平衡树题解

    [洛谷P3369][模板]普通平衡树题解 题目链接 题意: 您需要写一种数据结构(可参考题目标题),来维护一些数,其中需要提供以下操作:1. 插入x数2. 删除x数(若有多个相同的数,因只删除一个)3 ...

  6. 洛谷 P1992 不想兜圈的老爷爷 题解

    洛谷 P1992 不想兜圈的老爷爷 题解 题目描述 一位年过古稀的老爷爷在乡间行走 而他不想兜圈子 因为那会使他昏沉 偶然路过小A发扬助人为乐优良传统 带上地图 想知道路况是否一定使他清醒 usqwe ...

  7. BZOJ5285 & 洛谷4424 & UOJ384:[HNOI/AHOI2018]寻宝游戏——题解

    https://www.lydsy.com/JudgeOnline/problem.php?id=5285 https://www.luogu.org/problemnew/show/P4424 ht ...

  8. 斜率优化专题1——bzoj 1597 [Usaco2008 Mar] 土地购买 题解

    转载请注明:http://blog.csdn.net/jiangshibiao/article/details/24387147 [原题] 1597: [Usaco2008 Mar]土地购买 Time ...

  9. 洛谷p3384【模板】树链剖分题解

    洛谷p3384 [模板]树链剖分错误记录 首先感谢\(lfd\)在课上调了出来\(Orz\) \(1\).以后少写全局变量 \(2\).线段树递归的时候最好把左右区间一起传 \(3\).写\(dfs\ ...

随机推荐

  1. redmine本地安装部署

    1.railsinstaller-3.2.0.exe 下载地址 http://railsinstaller.org/en 安装railsinstaller  一直点next就可以了,安装完成之后C盘会 ...

  2. Appium(Python)API

    1.创建新的会话desired_caps = desired_caps = {  'platformName': 'Android',  'platformVersion': '7.0',  'dev ...

  3. Linux文件系统简介和软链接和硬链接的区别

    Linux有着极其丰富的文件系统,大体可分为如下几类: 网络文件系统:如nfs.cifs等: 磁盘文件系统:如ext3.ext4等: 特殊文件系统:如prco.sysfs.ramfs.tmpfs等: ...

  4. CSP201409-2:画图

    引言:CSP(http://www.cspro.org/lead/application/ccf/login.jsp)是由中国计算机学会(CCF)发起的"计算机职业资格认证"考试, ...

  5. 对HashMap进行排序

    首先来看看Map集合获取元素的三种常见方法keySet().values().entrySet() 1. values():返回map集合的所有value的Collection集合(于集合中无序存放) ...

  6. (原) MaterialEditor部- UmateriaEditor中 Node编译过程和使用(1)

    @author: 白袍小道 转载说明原处 插件同步在GITHUB: DaoZhang_XDZ     最后YY需求(手滑) 1.在理清楚基础套路和细节后,自定义纹理资源,并加入到现有UE材质系统 2. ...

  7. [Clr via C#读书笔记]Cp1CLR执行模型

    Cp1CLR执行模型 本章的概念点 CLR=Common Language Runtime 内存管理,程序集加载,安全性,异常处理和线程同步.CLR是基础,支持着面向它的各种语言.各种语言会被对应的编 ...

  8. leetcode个人题解——#15 3sums

    class Solution { public: vector<vector<int>> threeSum(vector<int>& nums) { sor ...

  9. centos配置iptables

    第一次配置前消除默认的规则 #这个一定要先做,不然清空后可能会悲剧 iptables -P INPUT ACCEPT #清空默认所有规则 iptables -F #清空自定义的所有规则 iptable ...

  10. 链表相加(Add Two Numbers)

    描述: 给定两个非空的链表,表示两个非负整数.数字以相反的顺序存储,每个节点包含一个数字.添加两个数字并将其作为链表返回. 您可以假设两个数字不包含任何前导零,除了数字0本身. 输入:(2 - > ...