土地征用 (Link

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

\(Line\) \(1:\) \(A\) \(single\) \(integer:\) \(N\)
\(Lines\) \(2..N+1:\) \(Line\) \(i+1\) \(describes\) \(plot\) \(i\) \(with\) \(two\) \(space-separated\) \(integers:\) \(width\) _ \(i\) \(and\) \(length\) _ \(i\)
输出格式:
\(Line\) \(1:\) \(The\) \(minimum\) \(amount\) \(necessary\) \(to\) \(buy\) \(all\) \(the\) \(plots.\)

我们定义结构体\(Edge\)中含有\(X,Y\)分别表示一块土地的长和宽。
考虑一块土地\(A\),如果有一块土地\(B\)的\(X\)和\(Y\)都大于\(A\),那么\(A\)的存在是没有意义的,因为\(A\)是可以不耗费任何代价被\(B\)所合并的,所以它不会对答案产生任何影响。于是我们考虑去掉这样所有的土地\(A\)。
首先我们将所有土地按照长度从小到大排序,长度相同的按照宽度从小到大排序。定义一个\(Stack\),然后连续将所有的土地入栈,在\(A\)入栈之前将之前栈中所有宽度小于等于\(A\)的土地全部弹出,然后入栈\(A\)。那么最后在栈中的元素就是我们所希望的元素。这里的元素是按照长度从小到大,宽度从大到小的顺序有序排列的。
那么显然我们每次合并的都是一个连续的区间。考虑使用\(DP\),易得状态转移方程:\(dp[i]=min_{j=1}^{j<=Top}(dp[i],dp[j]+Stack[j+1]*L[i])\),其中Stack里面存的是元素的宽度,L是栈中元素的长度。(因为有些土地被抛弃了所以我们不能继续使用\(Edge\)结构体),然而这样的时间复杂度会超时,考虑斜率优化。
我们看到后面的\(dp[j]+Stack[j+1]*L[i]\),设\(k=Stack[j+1],b=dp[j]\),然后\(x=L[i]\),那么我们就得到了直线方程:\(y=kx+b\)。套上斜率优化的板子即可。

#include <iostream>
#include <cstdio>
#include <cstring>
#include <algorithm>
#define MAXN 100010
#define LL long long
#define INF 0x7fffffff
using namespace std ;
LL N, Stack[MAXN], Top;
LL dp[MAXN], q[MAXN];
LL A[MAXN], B[MAXN];
LL L[MAXN];
inline void Read(LL & x){
    char C = getchar() ; x = 0 ;
    while(C < '0' || C > '9') C = getchar() ;
    while(C <= '9' && C >= '0')
        x = x * 10 + C - 48, C = getchar() ;
}
inline void Print(LL x){
    LL num = 0 ; char C[15] ;
    while(x) C[++ num] = (x % 10) + 48, x /= 10 ;
    while(num) putchar(C[num --]) ;
    putchar('\n') ;
}
struct Node{
    LL X, Y ;
}Edge[MAXN << 1];
inline bool Cmp(Node A, Node B){
    if(A.X == B.X) return A.Y < B.Y;
    else return A.X < B.X;
}
inline void Put_In_Stack(){
    for(int i = 1; i <= N; i ++){
        while(Top && Stack[Top] <= Edge[i].Y)
            Top -- ;
        Stack[++ Top] = Edge[i].Y ;
        L[Top] = Edge[i].X ;
    }
}
inline double Calc(LL i, LL j){
    return dp[j] + Stack[j + 1] * L[i] ;
}
inline bool Slope(LL a, LL b, LL c){
    return (B[c] - B[a]) * (A[b] - A[a]) - (B[b] - B[a]) * (A[c] - A[a]) >= 0;
}
int main(){
    Read(N) ;
    for(int i = 1; i <= N; i ++){
        Read(Edge[i].X) ;
        Read(Edge[i].Y) ;
    }
    sort(Edge + 1, Edge + N + 1, Cmp) ;
    Put_In_Stack() ;
    A[0] = Stack[1] ;
    LL Head = 1, Tail = 1 ;
    for(int i = 1;i <= Top; i ++){
        while(Head < Tail && Calc(i, q[Head]) >= Calc(i, q[Head + 1]))
            Head ++ ;
        dp[i] = Calc(i, q[Head]) ;
        A[i] = Stack[i + 1] ;
        B[i] = dp[i] ;
        while(Head < Tail && Slope(q[Tail - 1], q[Tail], i))
            Tail -- ;
        q[++ Tail] = i ;
    }
    Print(dp[Top]) ; return 0 ;
}

[LuoguP2900] [USACO08MAR]土地征用(Land Acquisition)的更多相关文章

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

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

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

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

  3. luogu P2900 [USACO08MAR]土地征用Land Acquisition

    写这道题时,预处理部分少打了等号,吓得我以为斜率优化错了或者被卡精了 mmp 首先有一个很明显的结论(逃),就是一个土地如果长(\(x\))与宽(\(y\))都比另一个土地小,那么这个土地一定可以跟那 ...

  4. 【洛谷 P2900】 [USACO08MAR]土地征用Land Acquisition(斜率优化,单调栈)

    题目链接 双倍经验 设\(H\)表示长,\(W\)表示宽. 若\(H_i<H_j\)且\(W_i<W_j\),显然\(i\)对答案没有贡献. 于是把所有点按\(H\)排序,然后依次加入一个 ...

  5. [USACO08MAR]土地征用Land Acquisition

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

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

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

  7. P2900 [USACO08MAR]土地征用Land Acquisition

    \(\color{#0066ff}{ 题目描述 }\) 约翰准备扩大他的农场,眼前他正在考虑购买N块长方形的土地.如果约翰单买一块土 地,价格就是土地的面积.但他可以选择并购一组土地,并购的价格为这些 ...

  8. Luogu 2900 [USACO08MAR]土地征用Land Acquisition

    斜率优化dp. 首先发现如果存在$x$和$y$使得$len(x) \geq len(y)$并且$wid(x) \geq wid(y)$,那么$y$直接不考虑就好了,因为在买$x$的时候就把$y$顺便带 ...

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

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

随机推荐

  1. [javaEE] jsp的九大隐式对象

    pageContext对象: 1.可以作为入口对象获取其他八大隐式对象的引用 1.1 getEXception获取exception隐世对象 1.2 getPage获取page对象 1.3 getRe ...

  2. Docker镜像保存为文件及从文件导入镜像的方法

    参考 1.概述 我们制作好镜像后,有时需要将镜像复制到另一台服务器使用. 能达到以上目的有两种方式,一种是上传镜像到仓库中(本地或公共仓库),但是另一台服务器很肯能只是与当前服务器局域网想通而没有公网 ...

  3. 程序员学炒股(6) 让我们来看一下7月份A股的表现

    有了前几天的数据准备,那让我们看一下7月份的股市是牛市还是熊市呢? 牛市和熊市主要就看股票的涨跌分布情况,虽然我们看大盘数据,但是不过中石油占的A股市值太大了,并且中石油95%的股票都是大股东控制的相 ...

  4. JavaScript中按键事件的e.keyCode || e.which || e.charCode

    1.浏览器的按键事件 浏览器有3种按键事件——keydown,keypress和keyup,分别对应onkeydown.onkeypress和onkeyup3个事件句柄. 一个典型的按键会产生所有这三 ...

  5. 1004. 填充矩形 (Standard IO)

    题目描述 已知矩形的大小为n×m,现用a×a的正方形填充该矩形.输入三个正整数n,m,a(n,m,a≤10^9),计算至多能填入多少正方形?(正方形可以正好碰到矩形边界,但不能超出矩形外) 输入 一行 ...

  6. 关于开发Cesium造成的电脑风扇狂飙的问题

    最近在开发Cesium的项目,每次一打开浏览器渲染3D 模型.风扇就狂飙起来,进任务管理器查看发现集显使用率100%,独显使用率0%.使用的是集显进行渲染.怪不得风扇会飙起来.既然知道问题所在,解决的 ...

  7. 1-3 Sass 语法、编译、调试

    Sass 语法格式 这里说的 Sass 语法是 Sass 的最初语法格式,他是通过 tab 键控制缩进的一种语法规则,而且这种缩进要求非常严格.另外其不带有任何的分号和大括号.常常把这种格式称为 Sa ...

  8. 各种优化方法总结比较(sgd/momentum/Nesterov/adagrad/adadelta)

    前言 这里讨论的优化问题指的是,给定目标函数f(x),我们需要找到一组参数x,使得f(x)的值最小. 本文以下内容假设读者已经了解机器学习基本知识,和梯度下降的原理. SGD SGD指stochast ...

  9. 【Python】内置方法pop

    此时 a,b 指向的地址所存的内容均被更改

  10. C++模板详解(系转载,但是个人添加了一些内容)

    原文地址:http://www.cnblogs.com/gw811/archive/2012/10/25/2738929.html 零.概述 模板是C++支持参数化多态的工具,使用模板可以使用户为类或 ...