数矩形(rectangle)


计算几何

把所有点两两连线,把这些线按长度排序,再按中点排序

能组成矩形的线一定是连续的

最坏就是所有点围成一个圆,交于圆心

复杂度O(可以过)

要用叉积,不然会被卡精

我居然认为极角序就是逆时针,错了好久

#include<cstdio>
#include<iostream>
#include<cstdlib>
#include<cstring>
#include<algorithm>
#include<cmath>
#define maxn 1505
#define eps 1e-11
using namespace std;
int n,tot;
struct po{
long long x,y,len,mx,my;
}s[maxn],a[maxn*maxn],t1,t2;
long long ans;
long long getl(int i,int j){
return (s[i].x-s[j].x)*(s[i].x-s[j].x)+(s[i].y-s[j].y)*(s[i].y-s[j].y);
}
bool cmp(po a,po b){
if(a.len==b.len)return a.mx<b.mx||a.mx==b.mx&&a.my<b.my;
return a.len<b.len;
}
long long cj(po a,po b){
return a.x*b.y-a.y*b.x;
}
bool pd(int i,int j)
{
if(getl(a[i].x,a[j].x)!=getl(a[i].y,a[j].y))return 0;
if(getl(a[i].x,a[j].y)!=getl(a[i].y,a[j].x))return 0;
return 1;
}
long long size(int i,int j){
po h[4];
h[0]=s[a[i].x],h[1]=s[a[j].y];
h[2]=s[a[i].y],h[3]=s[a[j].x];
long long sum=0;
for(int i=0;i<4;i++){
sum+=cj(h[i],h[(i+1)%4]);
}
return abs(sum);
}
int main(){
cin>>n;
for(int i=1;i<=n;i++)scanf("%lld%lld",&s[i].x,&s[i].y);
for(int i=1;i<=n;i++){
for(int j=i+1;j<=n;j++){
a[++tot].x=i,a[tot].y=j;
a[tot].mx=s[i].x+s[j].x,a[tot].my=s[i].y+s[j].y;
a[tot].len=getl(i,j);
}
}
sort(a+1,a+tot+1,cmp);
int l=1,now=1;
while(l<=tot){
while(a[l].len==a[now].len&&a[now].mx==a[l].mx&&a[now].my==a[l].my&&now<=tot)now++;
now--;
for(int i=l;i<=now;i++){
for(int j=i+1;j<=now;j++){
if(pd(i,j)){
ans=max(ans,size(i,j));
}
}
}
now++;l=now;
}
cout<<(long long)ans/2<<endl;
return 0;
}

bzoj2338数矩形(rectangle)的更多相关文章

  1. bzoj2338 数矩形

    给出N(N≤1500)个点,求选四个点作为顶点组成矩形的最大面积,保证有解. 对每两个点连边,按边长排序,枚举等长且中点相同的边作为对角线组成矩形,计算面积取最大值. 时间复杂度O(n2logn) # ...

  2. 【BZOJ2338】[HNOI2011]数矩形 几何

    [BZOJ2338][HNOI2011]数矩形 题解:比较直观的做法就是枚举对角线,两个对角线能构成矩形当且仅当它们的长度和中点相同,然后用到结论:n个点构成的矩形不超过n^2.5个(不会证),所以两 ...

  3. bzoj-2338 2338: [HNOI2011]数矩形(计算几何)

    题目链接: 2338: [HNOI2011]数矩形 Time Limit: 20 Sec  Memory Limit: 128 MB Description Input   Output 题意: 思路 ...

  4. bzoj2338[HNOI2011]数矩形 计算几何

    2338: [HNOI2011]数矩形 Time Limit: 20 Sec  Memory Limit: 128 MBSubmit: 1535  Solved: 693[Submit][Status ...

  5. 【BZOJ2338】【HNOI2011】数矩形 [计算几何]

    数矩形 Time Limit: 20 Sec  Memory Limit: 128 MB[Submit][Status][Discuss] Description 最近某歌手在研究自己的全国巡回演出, ...

  6. 数矩形(N - 暴力求解、打表)

    数矩形 Description 给你一个高为n ,宽为m列的网格,计算出这个网格中有多少个矩形,下图为高为2,宽为4的网格.            Input 第一行输入一个t, 表示有t组数据,然后 ...

  7. 【题解】Luogu P3217 [HNOI2011]数矩形

    原题链接:P3217 [HNOI2011]数矩形 什么??!怎么又是计算几何,您钛毒瘤了-- 这道题真的是毒瘤 凸包?旋转卡壳? 看一下数据,N<=1500? 暴力 没错,就是暴力,N^2没毛病 ...

  8. luogu P3217 [HNOI2011]数矩形

    LINK:数矩形 题意:给出n个点 求出一个最大的矩形. 矩形可以使斜着的.(不会告诉你样例我算了几年 这道题的一个潜规则 矩形面积都是整数 我也不知道为啥一定是整数 姑且是题目输出的要求吧. 所以用 ...

  9. BZOJ2338: [HNOI2011]数矩形

    题目:http://www.lydsy.com/JudgeOnline/problem.php?id=2338 中学数学老师告诉我们,一个矩形的两条对角线相等,所以只要把所有的边拿出来,记录下中点坐标 ...

随机推荐

  1. Python——函数入门(三)

    一.变量作用域 当程序定义一个变量时,这个变量是有它的作用范围的,变量的作用范围称为变量的作用域.根据变量的位置,分为两种: 局部变量:局部变量就是在函数中定义的变量,包括参数,都是局部变量,局部离开 ...

  2. CUDA中记录执行时间-GPU端

    事件eventcudaEvent_t start,stop;cudaEventCreate(&start);cudaEventCreate(&stop);cudaEventRecord ...

  3. KVM修改虚机网卡模式:由NAT模式改为Bridge模式

    1)关闭虚机# virsh  shutdown  vm1 2)编辑虚机配置文件# virsh  edit  vm1 <interface type='default'> 改为<int ...

  4. ZendFramework-2.4 源代码 - 关于MVC - Controller层

    // 1.控制器管理器 class ServiceManager implements ServiceLocatorInterface { public function __construct(Co ...

  5. Python知识点入门笔记——Python的基本数据类型

    Python的数字分为4种类型:整数(int).浮点数(float).布尔值(bool).复数(complex). type()函数可以知道数据的类型,如type(233)是int型,type(233 ...

  6. 哦?原来Python 面试题是这样的,Python面试题No19

    本面试题题库,由公号:非本科程序员 整理发布 第1题:是否遇到过python的模块间循环引用的问题,如何避免它? 这是代码结构设计的问题,模块依赖和类依赖 如果老是觉得碰到循环引用可能的原因有几点: ...

  7. [译]The Python Tutorial#3. An Informal Introduction to Python

    3. An Informal Introduction to Python 在以下示例中,输入和输出以提示符(>>>和...)的出现和消失来标注:如果想要重现示例,提示符出现时,必须 ...

  8. 精通SpringBoot---整合RabbitMQ消息队列

    今天来和朋友们一起学习下,SpringBoot怎么整合RabbitMQ.目前消息组件大致有三种:.activemq, rabbitmq, kafka.这三者各有优缺点,RabbitMQ相比之下是处于其 ...

  9. Python9-From-CSS-day48

    1.form表单相关内容前后端有数据交互的时候用form表单form表单提交数据的几个注意事项: 1.所有获取用户输入的标签都必须放在form表单里面 2.action 控制着往哪里提交 3.inpu ...

  10. [BZOJ1187]神奇游乐园(插头DP)

    Description 题意给定一个矩阵,每个格子有权值,在[-1000.1000]内,求一条回路使得回路经过权值和最大,每个格子最多经过一次 2≤n≤100,2≤m≤6 Code #include ...