这道题简直太好了,对于计算几何选手需要掌握的一个方法。

首先对于求解四边形面积,我们可以将四边形按对角线划分成两个三角形,显然此时四边形的面积最大最小值就变成了求解里这个对角线最近最远的点对。

对于此类问题有一个技巧,首先我们将点按照x为第一关键词y为第二关键词从小到大排序,然后我们开始取向量,并将所取的所有向量进行极角排序(斜率排序,叉积排序均可)。然后我们可以证明,第一条向量的两个端点在之前排序过的点的序列中是相邻的,如果这两个不是相邻的,说明中间存在一点并且满足中间的点的x大于左端点小于右端点,此时我们可以画图得知,这样会形成一条斜率更小的直线,与之前矛盾,所以这两个端点在原序列中必然相邻。接下来还有一个神奇的地方,这样的序列保证在序列的第一个点到向量的左端点的点距离这条直线单调递减,右侧亦如此,如果存在一个点比前一个点的距离要远,而这个点x大于前一个点的x,那么我们画图可知,这两点的斜率比当前斜率要小,则矛盾,以此证明出这样排序后的两条性质,那么我们考虑当我们旋转坐标系的时候,画图可知,受影响的点只有之前那条向量上的点,而且根据之前矛盾关系,之前那条的斜率大于现在这条,那么之前那条的两端点到这条线上的距离一个小一个大,那么我们只需要更换这两个点在序列中的位置,即可满足之前的单调性,所以每次旋转坐标系只需要交换上一条的向量两端点在排序后的序列中的位置即可,这样我们就维护出了距离对角线最远和最近的点,那么求解最大最小四边形面积也可以得出,当然也可以用此方法求得最大最小三角形面积,之前codeforce上有一题就是给定面积,去寻找是否存在三角形满足面积等于给定值,那么我们便可以用这个单调性以此基础上进行二分查找,所以此类方法复杂度为n2logn。

但是仅对于求解最大四边形三角形面积,还有一个更优的策略,我们可以得出,四边形上的四个点一定在凸包上,那么对于此类问题,我们便可以用旋转卡壳进行枚举,枚举每一条对角边,再用两个点去旋转,维护三角形最大值即可,对于三角形而言,三个端点仍然在凸包上,那么我们只需要固定一个点,旋转下两个端点即可,每次移动到该顶点处的三角形面最大位置即可,更新答案,此类方法复杂度nlogn

 1 //      ——By DD_BOND
2
3 //#include<bits/stdc++.h>
4 #include<functional>
5 #include<algorithm>
6 #include<iostream>
7 #include<sstream>
8 #include<iomanip>
9 #include<climits>
10 #include<cstring>
11 #include<cstdlib>
12 #include<cstddef>
13 #include<cstdio>
14 #include<memory>
15 #include<vector>
16 #include<cctype>
17 #include<string>
18 #include<cmath>
19 #include<queue>
20 #include<deque>
21 #include<ctime>
22 #include<stack>
23 #include<map>
24 #include<set>
25
26 #define fi first
27 #define se second
28 #define MP make_pair
29 #define pb push_back
30 #define INF 0x3f3f3f3f
31 #define pi 3.1415926535898
32 #define lowbit(a) (a&(-a))
33 #define lson l,(l+r)/2,rt<<1
34 #define rson (l+r)/2+1,r,rt<<1|1
35 #define Min(a,b,c) min(a,min(b,c))
36 #define Max(a,b,c) max(a,max(b,c))
37 #define debug(x) cerr<<#x<<"="<<x<<"\n";
38
39 using namespace std;
40
41 typedef long long ll;
42 typedef pair<int,int> P;
43 typedef pair<ll,ll> Pll;
44 typedef unsigned long long ull;
45
46 const ll LLMAX=2e18;
47 const int MOD=1e9+7;
48 const double eps=1e-12;
49 const int MAXN=1e6+10;
50 const int hmod1=0x48E2DCE7;
51 const int hmod2=0x60000005;
52
53 inline ll sqr(ll x){ return x*x; }
54 inline int sqr(int x){ return x*x; }
55 inline double sqr(double x){ return x*x; }
56 ll __gcd(ll a,ll b){ return b==0? a: __gcd(b,a%b); }
57 ll qpow(ll a,ll n){ll sum=1;while(n){if(n&1)sum=sum*a%MOD;a=a*a%MOD;n>>=1;}return sum;}
58 inline ll dcmp(ll x){ if(fabs(x)<eps) return 0; return (x>0? 1: -1); }
59
60 int p[2010];
61
62 struct Point{
63 int x,y,i,j;
64 Point(){ x=y=0; }
65 Point(int a,int b){ x=a,y=b; }
66 Point(int a,int b,Point p){ i=a,j=b,x=p.x,y=p.y; }
67 Point operator -(const Point &n)const{ return Point(x-n.x,y-n.y); }
68 bool operator <(const Point&n)const{ return x==n.x? y<n.y: x<n.x; }
69 void output(){ cout<<x<<' '<<y<<endl; }
70 }point[2010],vec[2*MAXN];
71
72 ll cross(Point a,Point b){ return 1ll*a.x*b.y-1ll*a.y*b.x; }
73
74 ll check(int i,int j,int k){ return abs(cross(point[j]-point[i],point[k]-point[i])); }
75
76 int main(void)
77 {
78 ios::sync_with_stdio(false); cin.tie(0); cout.tie(0);
79 ll n;
80 while(cin>>n){
81 ll s1=9e18,s2=0,cnt=0;
82 for(int i=0;i<n;i++) cin>>point[i].x>>point[i].y,p[i]=i;
83 if(n<4) return cout<<0<<' '<<0<<endl,0;
84 sort(point,point+n);
85 for(int i=0;i<n;i++)
86 for(int j=i+1;j<n;j++)
87 vec[cnt++]=Point(i,j,point[j]-point[i]);
88 sort(vec,vec+cnt,[](Point a,Point b){ return cross(a,b)>0; });
89 for(int i=0;i<cnt;i++){
90 int a=vec[i].i,b=vec[i].j;
91 if(p[a]>p[b]) swap(a,b);
92 if(p[a]!=0&&p[b]!=n-1) s2=max(s2,check(p[a],p[b],0)+check(p[a],p[b],n-1));
93 if(p[a]!=0&&p[b]!=n-1) s1=min(s1,check(p[a],p[b],p[a]-1)+check(p[a],p[b],p[b]+1));
94 swap(p[a],p[b]); swap(point[p[a]],point[p[b]]);
95 }
96 cout<<s1<<' '<<s2<<endl;
97 }
98 return 0;
99 }

HDU 6538 Neko and quadrilateral(极角排序+旋转坐标系)的更多相关文章

  1. 2017ACM暑期多校联合训练 - Team 7 1008 HDU 6127 Hard challenge (极角排序)

    题目链接 Problem Description There are n points on the plane, and the ith points has a value vali, and i ...

  2. HDU 5738 Eureka(极角排序)

    [题目链接] http://acm.hdu.edu.cn/showproblem.php?pid=5738 [题目大意] 给出平面中一些点,在同一直线的点可以划分为一个集合,问可以组成多少包含元素不少 ...

  3. 【极角排序+双指针线性扫】2017多校训练七 HDU 6127 Hard challenge

    acm.hdu.edu.cn/showproblem.php?pid=6127 [题意] 给定平面直角坐标系中的n个点,这n个点每个点都有一个点权 这n个点两两可以连乘一条线段,定义每条线段的权值为线 ...

  4. HDU Always Cook Mushroom (极角排序+树状数组)

    Problem Description Matt has a company, Always Cook Mushroom (ACM), which produces high-quality mush ...

  5. hdu 5738 Eureka 极角排序+组合数学

    Eureka Time Limit: 8000/4000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others)Total Subm ...

  6. POJ 2280 Amphiphilic Carbon Molecules 极角排序 + 扫描线

    从TLE的暴力枚举 到 13313MS的扫描线  再到 1297MS的简化后的扫描线,简直感觉要爽翻啦.然后满怀欣喜的去HDU交了一下,直接又回到了TLE.....泪流满面 虽说HDU的时限是2000 ...

  7. poj2280Amphiphilic Carbon Molecules(极角排序)

    链接 卡了几天的破题,对于hdu的那份数据,这就一神题.. 借助极角排序,枚举以每一个点进行极角排序,然后构造两条扫描线,一个上面一个下面,两条同时走,把上线和下线的点以及上线左边的点分别统计出来,如 ...

  8. 【极角排序、扫描线】UVa 1606 - Amphiphilic Carbon Molecules(两亲性分子)

    Shanghai Hypercomputers, the world's largest computer chip manufacturer, has invented a new class of ...

  9. UVa 1606 (极角排序) Amphiphilic Carbon Molecules

    如果,没有紫书上的翻译的话,我觉得我可能读不懂这道题.=_=|| 题意: 平面上有n个点,不是白点就是黑点.现在要放一条直线,使得直线一侧的白点与另一侧的黑点加起来数目最多.直线上的点可以看作位于直线 ...

随机推荐

  1. 洛谷 P4665 [BalticOI 2015]Network

    洛谷 P4665 [BalticOI 2015]Network 你有一棵 $ n $ 个节点的树,你可以在树上加一些边,使这棵树变成一张无重边.自环的图,且删掉任意一条边它仍然联通.求最少要加多少条边 ...

  2. java 工具包

    https://www.cnblogs.com/aligege/p/8521934.html https://gitee.com/loolly/hutool https://blog.csdn.net ...

  3. react 详细解析学习笔记

    React的介绍: React来自于Facebook公司的开源项目 React 可以开发单页面应用       spa(单页面应用) react 组件化模块化  开发模式 React通过对DOM的模拟 ...

  4. 【NOIP2013模拟】导弹防御塔

    题目 Freda的城堡-- "Freda,城堡外发现了一些入侵者!" "喵...刚刚探究完了城堡建设的方案数,我要歇一会儿嘛lala~" "可是入侵者 ...

  5. get和post请求方式的区别,常见状态码的整理

    get和post的区别 get和post是什么? HTTP协议中的两种发送请求的方法.get从指定的资源请求数据: post向指定的资源提交要被处理的数据. HTTP是什么? 超文本传输协议(HTTP ...

  6. jq 获取各个元素的宽度高度的方法

    JS获取各种宽度.高度的简单介绍: scrollHeight: 获取对象的滚动高度. scrollLeft:设置或获取位于对象左边界和窗口中目前可见内容的最左端之间的距离 scrollTop:设置或获 ...

  7. CodeForces 1197D Yet Another Subarray Problem

    Time limit 2000 ms Memory limit 262144 kB Source Educational Codeforces Round 69 (Rated for Div. 2) ...

  8. Redis-cli相关命令

    > flushdb > SELECT OK []> GET db_number (nil) []> []> flushdb OK []> SELECT OK > ...

  9. electron原来这么简单----打包你的react、VUE桌面应用程序

    也许你不甘心只写网页,被人叫做"他会写网页",也许你有项目需求,必须写桌面应用,然而你只会前端,没关系.网上的教程很多,但是很少有能说的浅显易懂的,我尽力将electron打包应用 ...

  10. React-Native 之 GD (十)Android启动页面 及 模态方式跳转

    1.Android启动页面 思路:新建一个组件作为 Android 的启动页,index.android.js 的初始化窗口改为 Android启动页,设置定时器,使其在1.5秒后自动跳转到 Main ...