有2N个矩形,这些矩形被标号为0 ~ 2N-1,对于第i个矩形其长宽分别为X[i]与Y[i]。现在要把这2N个矩形分为两组,每组N个,每个矩形恰好分到两组中的一组里。分成两组后,设两组分别为A组、B组,对于每一组矩形,你需要分别完成如下任务:
将该组中的N个矩形依次放在一个平面上,可以相互重叠,要求每个矩形的4条边都平行于平面坐标系的X轴或Y轴,矩形在摆放时可以旋转90度后再摆放。N个矩形摆放完后,使这N个矩形共同重叠的面积最大;设A组的最大面积为SA,B组的最大面积为SB。
请寻找一种恰当的分组方法,使SA+SB最大,并输出SA+SB的这个极值。
存在一组最优解,满足所有x>y的都被旋转了90度(即swap(x,y))。
考虑x最小和y最小的矩形,如果有多个任选一个。如果x,y同时最小,那么只需在剩余2n-1个矩形中选n个使面积交最大,否则分类这两个某一维最小的矩形是否在同一组,如果同组的话类似的只需在剩余2n-2个矩形中选n个使面积交最大,不同组则把剩余2n-2个等分成两组,使第一组x最大,第二组y最大。这三个过程很类似,都可以枚举一维的最值,另一维的最值用堆优化贪心确定。
#include<bits/stdc++.h>
const int N=,inf=0x3f3f3f3f;
typedef long long i64;
int n,pp,mx=inf,my=inf,sd=;
int min(int a,int b){return a<b?a:b;}
void mins(int&a,int b){if(a>b)a=b;}
void maxs(i64&a,i64 b){if(a<b)a=b;}
struct pos{
int x,y;
void R(){
scanf("%d%d",&x,&y);
if(x>y)std::swap(x,y);
mins(mx,x);mins(my,y);
}
bool operator<(const pos&w)const{return x<w.x;}
}ps[N],pmx,pmy;
struct cmpy1{bool operator()(const pos&a,const pos&b){return a.y>b.y;}};
struct cmpy2{bool operator()(const pos&a,const pos&b){return a.y<b.y;}};
i64 cal1(){
i64 s=;
if(!sd)sd=,std::sort(ps+,ps+pp+);
std::priority_queue<pos,std::vector<pos>,cmpy1>q;
for(int i=pp;i;--i){
q.push(ps[i]);
if(q.size()>n)q.pop();
if(q.size()==n)maxs(s,q.top().y*i64(ps[i].x));
}
return s+i64(mx)*my;
}
int ys[N];
i64 cal2(){
i64 s=;
if(!sd)sd=,std::sort(ps+,ps+pp+);
ys[]=inf;
int y0=pmx.y;
for(int i=;i<=pp;++i)ys[i]=ys[i-],mins(ys[i],ps[i].y);
std::priority_queue<pos,std::vector<pos>,cmpy2>q;
for(int i=pp;i;--i){
q.push(ps[i]);
if(q.size()>n-)mins(y0,q.top().y),q.pop();
if(q.size()==n-)maxs(s,i64(min(ps[i].x,pmy.x))*my+i64(min(ys[i-],y0))*mx);
}
return s;
}
int main(){
scanf("%d",&n);
pp=n*;
for(int i=;i<=pp;++i)ps[i].R();
for(int i=;i<=pp;++i)if(ps[i].x==mx){pmx=ps[i];ps[i]=ps[pp--];break;}
if(pmx.y==my)return printf("%lld",cal1()),;
for(int i=;i<=pp;++i)if(ps[i].y==my){pmy=ps[i];ps[i]=ps[pp--];break;}
return printf("%lld",std::max(cal1(),cal2())),;
}

51nod1302 矩形面积交的更多相关文章

  1. 2019计蒜之道初赛4 B. 腾讯益智小游戏—矩形面积交(简单)(矩形交集)

    B. 腾讯益智小游戏—矩形面积交(简单) 1000ms 262144K   腾讯游戏开发了一款全新的编程类益智小游戏,最新推出的一个小游戏题目是关于矩形面积交的.聪明的你能解出来吗?看下面的题目接招吧 ...

  2. HDU - 1255 覆盖的面积(线段树求矩形面积交 扫描线+离散化)

    链接:线段树求矩形面积并 扫描线+离散化 1.给定平面上若干矩形,求出被这些矩形覆盖过至少两次的区域的面积. 2.看完线段树求矩形面积并 的方法后,再看这题,求的是矩形面积交,类同. 求面积时,用被覆 ...

  3. C语言 · 矩形面积交

    问题描述 平面上有两个矩形,它们的边平行于直角坐标系的X轴或Y轴.对于每个矩形,我们给出它的一对相对顶点的坐标,请你编程算出两个矩形的交的面积. 输入格式 输入仅包含两行,每行描述一个矩形. 在每行中 ...

  4. Java实现 蓝桥杯VIP基础练习 矩形面积交

    描述 平面上有两个矩形,它们的边平行于直角坐标系的X轴或Y轴.对于每个矩形,我们给出它的一对相对顶点的坐标,请你编程算出两个矩形的交的面积. 输入 输入仅包含两行,每行描述一个矩形. 在每行中,给出矩 ...

  5. 2015 UESTC 数据结构专题E题 秋实大哥与家 线段树扫描线求矩形面积交

    E - 秋实大哥与家 Time Limit: 1 Sec  Memory Limit: 256 MB 题目连接 http://acm.uestc.edu.cn/#/contest/show/59 De ...

  6. 【hdu1255】线段树求矩形面积交

    题意大概就是上图这个样子.<=100组测试数据,每组<=1000个矩形. 题解: 这个问题怎么解决..做了上一题矩形面积并应该就会了.. 对于每个节点维护3个值: cnt:该节点所代表的这 ...

  7. Codeforces Round #524 (Div. 2)C 二维坐标系求俩矩形面积交

    题:https://codeforces.com/contest/1080/problem/C 题意:给n*m的二维坐标系,每个位置(xi,yi)都表示一个方格,(1,1)的位置是白色,整个坐标系黑白 ...

  8. Gym-100935I Farm 计算几何 圆和矩形面积交

    题面 题意:就是给你一个圆,和你一个矩形,求面积并,且 保证是一种情况:三角剖分后 一个点在圆内 两个在圆外 题解:可以直接上圆与凸多边形交的板子,也可以由这题实际情况,面积等于扇形减两个三角形 #i ...

  9. hdu1255(线段树——矩形面积交)

    题目连接:http://acm.hdu.edu.cn/showproblem.php?pid=1255 题意:求N个矩形中,求被覆盖至少俩次的面积和 分析:覆盖两次即col[rt]>=2就好.一 ...

随机推荐

  1. rest-framework之分页器

    rest-framework之分页器 本文目录 一 简单分页(查看第n页,每页显示n条) 二 偏移分页(在第n个位置,向后查看n条数据) 三 CursorPagination(加密分页,只能看上一页和 ...

  2. 计算x

    如果x的x次幂结果为10(参见[图1.png]),你能计算出x的近似值吗? 显然,这个值是介于2和3之间的一个数字. 请把x的值计算到小数后6位(四舍五入),并填写这个小数值. 注意:只填写一个小数, ...

  3. (20)jQuery的文档操作(创建,添加、设置样式和删除等)

    <!DOCTYPE html><html><head> <meta charset="UTF-8"> <title>jq ...

  4. 《DSP using MATLAB》Problem 5.2

    代码: %% ---------------------------------------------------------------------------------- %% Output ...

  5. Java线程池 详解(图解)

    来源:www.jianshu.com/p/098819be088c 拓展: 手动创建 new ThreadPoolExecutor 的使用: https://segmentfault.com/a/11 ...

  6. SQL将时间格式化为year-month-day

    SQL将输出年月日格式化为:2017-12-3-28 CONVERT(varchar(100),RunDate, 23) AS RunDate,

  7. 【HAOI2012】外星人

    又犯sb错了QAQ 原题: 艾莉欧在她的被子上发现了一个数字 ,她觉得只要找出最小的x使得,.根据这个 她就能找到曾经绑架她的外星人的线索了.当然,她是不会去算,请你帮助她算出最小的x. test&l ...

  8. SQLite数据库下载

    一:SQLite简介 SQLite是一种嵌入式数据库,它的数据库就是一个文件.体积很小,经常被集成到各种应用程序中,甚至在iOS和Android的App中都可以集成. 要操作关系数据库,首先需要连接到 ...

  9. MySQL Inport--导入数据

    LOAD DATA INFILE导入数据 语法: LOAD DATA [LOW_PRIORITY | CONCURRENT] [LOCAL] INFILE '' [REPLACE | IGNORE] ...

  10. oracle之 AWR固定基线

    前言:可以创建AWR基线来为数据库建立已保存的工作负载视图,以便以后用来与其他AWR快照进行比较. 1. 手工创建 AWR 固定基线(固定基线如果没有设置过期时间,会永久保存) -- 根据时间创建DB ...