计算几何经典题,贴板子。

Description

  在某块平面土地上有N个点,你可以选择其中的任意四个点,将这片土地围起来,当然,你希望这四个点围成的多边形面积最大。

Input

  第1行一个正整数N,接下来N行,每行2个数x,y,表示该点的横坐标和纵坐标。

Output

  最大的多边形面积,答案精确到小数点后3位。

Sample Input

  5
  0 0
  1 0
  1 1
  0 1
  0.5 0.5

Sample Output

  1.000

HINT

  数据范围 n<=2000,|x|,|y|<=100000。

Solution

  求N个点中最大四边形的面积,然而实际上这道题求的是凸四边形的面积,数据中似乎并没有三角形凸包这种东西。

  我们回顾一下经典问题,在N个点中取出面积最大的三角形怎么做。

  首先我们很容易得出,最大三角形的3个点肯定都在凸包上。

  所以先求出N个点的凸包,然后用旋转卡壳来做:

  设A1~AM为凸包上逆时针顺序排列的点。

  枚举三角形底边一端点Ai,求出距离AiAi+1最远的凸包上的点Ak;

  然后从Ai+1起枚举三角形底边另一端点Aj,根据Ak求出距离AiAj最远的凸包上的点Ak'。

  因为j从i+1开始递增,所以k'也从k开始单调递增;

  同理又因为i是单调递增,k也是随着i单调递增。

  以上两行就是巧妙地利用旋转卡壳在O(n^2)的时间内解决了最大三角形的问题。

  旋转卡壳实际上就是用在二次函数上的三分法求得最远点。

  最大三角形可以做,最大四边形不是同样的思路吗?(想好了再往下看吧)

  三角形是枚举底边,四边形枚举对角线就行啦。

  在对角线两边各做一个旋转卡壳就行,其实就是相当于两边各找一个最大三角形。时间复杂度还是O(n^2)。

#include <cstdio>
#include <algorithm>
#include <cstring>
#define MN 2005
#define eps 1e-12
using namespace std;
struct vec
{
double x,y;
friend vec operator-(const vec& a,const vec& b) {return (vec){a.x-b.x,a.y-b.y};}
friend double operator/(const vec& a,const vec& b) {return a.x*b.y-a.y*b.x;}
friend double abs(const vec& a) {return a.x*a.x+a.y*a.y;}
}a[MN],q[MN<<];
int n,tp;
double ans; inline int read()
{
int n=,f=; char c=getchar();
while (c<'' || c>'') {if(c=='-')f=-; c=getchar();}
while (c>='' && c<='') {n=n*+c-''; c=getchar();}
return n*f;
} bool cmp1(const vec& A,const vec& B) {return A.y<B.y||A.y==B.y&&A.x<B.x;}
bool cmp2(const vec& A,const vec& B) {return (A-a[])/(B-a[])>=eps;}
inline bool check(const vec& A,const vec& B,const vec& C)
{
vec AB=B-A,AC=C-A;
if (AB/AC<) return true;
else if (AB/AC<eps&&abs(AB)<abs(AC)) return true;
return false;
} int main()
{
register int i,j,uj,luj,ldj;
scanf("%d",&n);
for (i=;i<=n;++i) scanf("%lf%lf",&a[i].x,&a[i].y);
sort(a+,a+n+,cmp1); sort(a+,a+n+,cmp2);
for (q[tp=]=a[],i=;i<=n;q[++tp]=a[i++])
for (;tp>&&check(q[tp-],q[tp],a[i]);--tp);
for (i=;i<=tp;++i) q[tp+i]=q[i];
for (i=,uj=;i<=tp;++i)
{
for (;(q[i+]-q[i])/(q[uj+]-q[i])>(q[i+]-q[i])/(q[uj]-q[i]);++uj);
for (j=i+,ldj=i+,luj=uj;j<=i+tp-;++j)
{
for (;(q[j]-q[i])/(q[luj+]-q[i])>(q[j]-q[i])/(q[luj]-q[i]);++luj);
for (;(q[ldj+]-q[i])/(q[j]-q[i])>(q[ldj]-q[i])/(q[j]-q[i]);++ldj);
ans=max(ans,((q[j]-q[i])/(q[luj]-q[i])+(q[ldj]-q[i])/(q[j]-q[i]))/);
}
}
printf("%.3lf",ans);
}

Last Word

  所以最大五边形也是可以做的咯?

[BZOJ]1069 最大土地面积(SCOI2007)的更多相关文章

  1. BZOJ 1069 最大土地面积

    Description 在某块平面土地上有N个点,你可以选择其中的任意四个点,将这片土地围起来,当然,你希望这四个点围成的多边形面积最大. Input 第1行一个正整数N,接下来N行,每行2个数x,y ...

  2. 【BZOJ】【1069】【SCOI2007】最大土地面积

    计算几何/旋转卡壳 从已知点中选出四个使得选出的四边形面积最大,很明显我们应该在凸包上搞. 我一开始的思路是:枚举 i ,找到 i 的对锺点cur1,这两个点将凸包分成了两半,我们在左半中枚举一个 j ...

  3. bzoj 1069 [SCOI2007]最大土地面积(旋转卡壳)

    1069: [SCOI2007]最大土地面积 Time Limit: 1 Sec  Memory Limit: 162 MBSubmit: 2277  Solved: 853[Submit][Stat ...

  4. BZOJ 1069: [SCOI2007]最大土地面积 [旋转卡壳]

    1069: [SCOI2007]最大土地面积 Time Limit: 1 Sec  Memory Limit: 128 MBSubmit: 2978  Solved: 1173[Submit][Sta ...

  5. BZOJ 1069: [SCOI2007]最大土地面积(旋转卡壳)

    题目链接~ 1069: [SCOI2007]最大土地面积 思路很简单,极角排序求完凸包后,在凸包上枚举对角线,然后两边分别来两个点旋转卡壳一下,搞定! 不过计算几何的题目就是这样,程序中间的处理还是比 ...

  6. ●BZOJ 1069 [SCOI2007]最大土地面积

    题链: http://www.lydsy.com/JudgeOnline/problem.php?id=1069 题解: 计算几何,凸包,旋转卡壳 其实和这个题差不多,POJ 2079 Triangl ...

  7. bzoj 1069 [SCOI2007]最大土地面积——旋转卡壳

    题目:https://www.lydsy.com/JudgeOnline/problem.php?id=1069 发现 n 可以 n^2 .所以枚举对角线,分开的两部分三角形就可以旋转卡壳了. 注意坐 ...

  8. [BZOJ]1069: [SCOI2007]最大土地面积

    题目大意:给出二维平面上n个点,求最大的由这些点组成的四边形面积.(n<=2000) 思路:求出凸包后旋转卡壳枚举对踵点对作为四边形的对角线,枚举或二分另外两个点,复杂度O(n^2)或O(nlo ...

  9. bzoj 1069: [SCOI2007]最大土地面积 凸包+旋转卡壳

    题目大意: 二维平面有N个点,选择其中的任意四个点使这四个点围成的多边形面积最大 题解: 很容易发现这四个点一定在凸包上 所以我们枚举一条边再旋转卡壳确定另外的两个点即可 旋(xuan2)转(zhua ...

随机推荐

  1. phalcon框架命名空间

    命名空间第一影像就是实际上就相当宏定义,就是需要把一个很长的带有路径的类文件指定一个空间,然后就可直接用简单简写模式 当然如果是外部文件需要首先引入外部文件,如果不引入外部文件还是会报错.一般最会出错 ...

  2. C语言学习(二)

    今天在程序员面试题中,碰到一个有意思的题目:数组a[N],存放了1至N-1个数,其中某个数重复一次,现在要求找出重复的数字且程序时间复杂度必须为O(N).乍一看,如果不计时间复杂度和空间复杂度程序比较 ...

  3. OAuth2.0学习(1-1)OAuth2.0是什么?

    目前很多开放平台如新浪微博开放平台都在使用提供开放API接口供开发者使用,随之带来了第三方应用要到开放平台进行授权的问题 OAuth就是用于为第三方应用授权访问用户的资源应用的. 目前有OAuth1. ...

  4. 关于阿里巴巴iconfont的使用方法

    iconfont网址:http://www.iconfont.cn/ 说起iconfont,做前端开发的应该知道它的好处,图标库之丰富,只有你想不到的,没有你找不到的,而且轻量高清.用户在iconfo ...

  5. 【Vue中的swiper轮播组件】

    <template> <swiper :options="swiperOption" ref="mySwiper"> <!-- s ...

  6. 算法 排序lowB三人组 冒泡排序 选择排序 插入排序

    参考博客:基于python的七种经典排序算法   [经典排序算法][集锦]     经典排序算法及python实现 首先明确,算法的实质 是 列表排序.具体就是操作的列表,将无序列表变成有序列表! 一 ...

  7. 微信 登录 Scope 参数错误或没有 Scope 权限

    //电脑端 扫码授权登录 public static string AuthUrl = "https://open.weixin.qq.com/connect/qrconnect?appid ...

  8. 04、NetCore2.0下Web应用之Startup源码解析

    04.NetCore2.0Web应用之Startup源码解析   通过分析Asp.Net Core 2.0的Startup部分源码,来理解插件框架的运行机制,以及掌握Startup注册的最优姿势. - ...

  9. CSS 选择器简介

    前言:这是笔者学习之后自己的理解与整理.如果有错误或者疑问的地方,请大家指正,我会持续更新! 选择器权重 如果以4位数表示选择符权重,那么: 元素选择器的权重是1: id 选择器的权重为100: cl ...

  10. Lintcode375 Clone Binary Tree solution 题解

    [题目描述] For the given binary tree, return a deep copy of it. 深度复制一个二叉树,给定一个二叉树,返回一个他的克隆品. [题目链接] www. ...