「ICPC2017 WF」Money for Nothing

传送门

我们可将生产商和消费商都看成二维平面上的点,其坐标分别为 \((d_i,p_i)\),\((e_i,q_i)\)。

那么问题转变为:

给定平面上的 \(m\) 个 \(A\) 类点 \((d_i,p_i)\),以及 \(n\) 个 \(B\) 类点 \((e_i,q_i)\)。求选择一个 \(A\) 类点作为矩形左下角,一个 \(B\) 类点作为矩形右上角所能得到的最大面积。若不存在这样的矩形就输出零。

考虑如下几种情况。

在这种情况下 \(A_1,A_2\) 都能与 \(B\) 围成一个矩形,但显然 \(A_1\) 更优秀。

故对于这样的 \(A\) 点我们可以直接舍弃。

在这种情况下 \(B_1,B_2\) 都能与 \(A\) 围成一个矩形,但显然 \(B_1\) 更优秀。

故对于这样的 \(B\) 点我们可以直接舍弃。

舍弃掉这些点过后两种点在平面上的排布一定是这样的:

然后我们考虑这样一种情况:

设 \(A_1,B_1\) 围成的矩形是以 \(A_1\) 为左下角的矩形当中最大的那一个。

我们可以得到这样一个结论:

\(A_2\) 和 \(B_2\) 围成的矩形的大小一定小于 \(A_2\) 和 \(B_1\) 围成的矩形的大小。

我们给这几个部分编个号,下面用编号代替上图中的部分。

根据我们前面的条件,有 \(3+4+5>3+4+1+2\rightarrow 5>1+2\)。

我们要证明的即 \(4+6+5+7>4+6+2\rightarrow 5+7>2\rightarrow 1+2+7> 2\)。

所以我们推广一下可以得到这样一个结论:对于每个红点,其围成最大矩形的黄点具有单调性。

根据这个性质我们直接分治就好了。

总时间复杂度为 \(O(n\log_2n)\)。

/*---Author:HenryHuang---*/
/*---Never Settle---*/
#include<bits/stdc++.h>
using namespace std;
typedef long long LL;
const int maxn=5e5+5;
struct cc{
int x,y;
LL operator*(const cc &h)const{
return 1ll*(h.x-x)*(h.y-y);
}
}a[maxn],b[maxn],p[maxn];
int sa,sb;
LL Ans;
void solve(int l,int r,int ll,int rr){
if(l>r||ll>rr) return ;
int mid=(l+r)>>1;
LL ans=-1e18,id=0;
for(int i=ll;i<=rr;++i){
if(a[mid].x<b[i].x||a[mid].y<b[i].y){
if(a[mid]*b[i]>ans){
ans=a[mid]*b[i];
id=i;
}
}
}
if(id!=0){
solve(l,mid-1,ll,id);
solve(mid+1,r,id,rr);
Ans=max(Ans,ans);
} }
int main(){
ios::sync_with_stdio(0);
cin.tie(0),cout.tie(0);
int m,n;cin>>m>>n;
for(int i=1;i<=m;++i){
cin>>p[i].x>>p[i].y;
}
sort(p+1,p+m+1,[&](cc a,cc b){return a.x==b.x?a.y<b.y:a.x<b.x;});
a[++sa]=p[1];
for(int i=2;i<=m;++i){
if(a[sa].y>p[i].y) a[++sa]=p[i];
}
for(int i=1;i<=n;++i){
cin>>p[i].x>>p[i].y;
}
sort(p+1,p+n+1,[&](cc a,cc b){return a.x==b.x?a.y<b.y:a.x<b.x;});
reverse(p+1,p+n+1);
b[++sb]=p[1];
for(int i=2;i<=n;++i){
if(b[sb].y<p[i].y) b[++sb]=p[i];
}
reverse(b+1,b+sb+1);
for(int i=1;i<=sb;++i) cout<<b[i].x<<' '<<b[i].y<<'\n';
solve(1,sa,1,sb);
cout<<Ans<<'\n';
return 0;
}

GYM101471D「ICPC2017 WF」Money for Nothing的更多相关文章

  1. 前端构建工具之gulp(一)「图片压缩」

    前端构建工具之gulp(一)「图片压缩」 已经很久没有写过博客了,现下终于事情少了,开始写博吧 今天网站要做一些优化:图片压缩,资源合并等 以前一直使用百度的FIS工具,但是FIS还没有提供图片压缩的 ...

  2. fir.im Weekly - 如何打造 Github 「爆款」开源项目

    最近 Android 转用 Swift 的传闻甚嚣尘上,Swift 的 Github 主页上已经有了一次 merge>>「Port to Android」,让我们对 Swift 的想象又多 ...

  3. 更新日志 - fir.im「高级统计」功能上线

    距离 2016 年到来只剩 10 个日夜,fir.im 也准备了一些新鲜的东西,比如「高级统计」功能和「跳转应用商店」功能,帮助你更好地管理.优化应用,欢迎大家试用反馈:) 新增高级统计功能 这次更新 ...

  4. Notepad++ 开启「切分窗口」同时检视、比对两份文件

    Notepad++ 是个相当好用的免费纯文本编辑器,除了内建的功能相当多之外,也支持外挂模块的方式扩充各方面的应用.以前我都用 UltraEdit 跟 Emeditor,后来都改用免费的 Notepa ...

  5. 「zigbee - 1」工欲善其事必先利其器 - IAR for 8051 IDE customization

    最近在实验室做一些 Zigbee 相关的事情,然而一直没在博客上记录啥东西,也不像原来在公司有动力在 Confluence wiki 上扯东扯西.直到前些阵子,跑到 feibit 论坛上(国内较大的一 ...

  6. 「C语言」文件的概念与简单数据流的读写函数

    写完「C语言」单链表/双向链表的建立/遍历/插入/删除 后,如何将内存中的链表信息及时的保存到文件中,又能够及时的从文件中读取出来进行处理,便需要用到”文件“的相关知识点进行文件的输入.输出. 其实, ...

  7. 「C语言」Windows+EclipseCDT下的C语言开发环境准备

    之前写过一篇 「C语言」在Windows平台搭建C语言开发环境的多种方式 ,讨论了如何在Windows下用DEV C++.EclipseCDT.VisualStudio.Sublime Test.Cl ...

  8. 如何对抗 WhatsApp「蓝色双勾」-- 3 个方法让你偷偷看讯息

    WhatsApp 强制推出新功能「蓝色双勾 (✔✔)」 ,让对方知道你已经看过讯息.一众用户反应极大,因为以后不能再藉口说未看到讯息而不回覆.究竟以后 WhatsApp 是否真的「更难用」? 幸好还有 ...

  9. FileUpload控件「批次上传 / 多档案同时上传」的范例--以「流水号」产生「变量名称」

    原文出處  http://www.dotblogs.com.tw/mis2000lab/archive/2013/08/19/multiple_fileupload_asp_net_20130819. ...

随机推荐

  1. 如何彻底禁止 macOS Big Sur 自动更新,去除更新标记和通知

    作者:gc(at)sysin.org,主页:www.sysin.org 请访问原文链接:https://sysin.org/article/Disable-macOS-Update/,查看最新版.原创 ...

  2. TVM图优化与算子融合

    TVM图优化与算子融合 计算图的定义 Computational graphs: a common way to represent programs in deep learning framewo ...

  3. NVIDIA GPU上的直接线性求解器

    NVIDIA GPU上的直接线性求解器 NVIDIA cuSOLVER库提供了密集且稀疏的直接线性求解器和本征求解器的集合,它们为计算机视觉,CFD,计算化学和线性优化应用程序提供了显着的加速.cuS ...

  4. 深度学习调用TensorFlow、PyTorch等框架

    深度学习调用TensorFlow.PyTorch等框架 一.开发目标目标 提供统一接口的库,它可以从C++和Python中的多个框架中运行深度学习模型.欧米诺使研究人员能够在自己选择的框架内轻松建立模 ...

  5. VB 老旧版本维护系列---尴尬的webapi访问返回json对象

    尴尬的webapi访问返回json对象 首先Imports Newtonsoft.Json Imports MSXML2(Interop.MSXML2.dll) Dim URLEncode As Sy ...

  6. VB 老旧版本维护系列---迷之集合- dataTable

    迷之集合- dataTable '定义一个datatable,并声明一个空对象 Dim data As DataTable = New DataTable() '获取行数 Dim rows As In ...

  7. ContOS8 使用yum安装MariaDB

    首先全部删除MySQL/MariaDB(若是首次安装可根据需要跳过此步) 若不清楚MySQL和MariaDB的关系请移步至 Mariadb百科 1.查看系统版本(以下任一命令即可). # cat /p ...

  8. SpringCloud Alibaba实战(5:子模块基本业务开发)

    源码地址:https://gitee.com/fighter3/eshop-project.git 持续更新中-- 在上一节里,我们搭建了一个微服务项目的整体架构,并进行了版本控制. 接下来我们进一步 ...

  9. P4779 【模板】单源最短路径(标准版)单源最短路Dijkstra

    题目描述 给定一个$n$个点,$m$条有向边的带非负权图,请你计算从$s$出发,到每个点的距离. 数据保证你能从$s$出发到任意点. 输入格式 第一行为三个正整数$n,m,s$. 第二行起$m$行,每 ...

  10. C# Net Core 使用 itextsharp.lgplv2.core 把Html转PDF

    C# Net Core 使用 itextsharp.lgplv2.core 把Html转PDF 只支持英文(中文我不知道怎么弄,懂的朋友帮我看一下)!!!!![补充:评论区的小伙伴已解决] 引入包it ...