点击打开hdu2202

思路:最大三角形面积,那么肯定这三个点在最外围,所以先求凸包,然后用旋转卡壳求出那三个点求出面积最大。

#include <iostream>
#include <algorithm>
#include <iomanip>
#include<stdio.h>
using namespace std;
const int maxn = 50010;
struct Point {int x , y;bool operator < (Point const &rhs) const {return (x < rhs.x) || (x == rhs.x && y < rhs.y);}
};int Cross(Point const &O , Point const &A , Point const &B)
{int xoa = A.x - O.x;int xob = B.x - O.x;int yoa = A.y - O.y;int yob = B.y - O.y;return xoa * yob - xob * yoa;
}
int Andrew(Point *p , int n , Point *ch)
{sort(p , p + n);int m = 0;for(int i = 0; i < n; i++){ //下凸包while(m > 1 && Cross(ch[m-2] , ch[m-1] , p[i]) < 0) m--;ch[m++] = p[i];}int k = m;for(int i = n - 2; i >= 0; i--) {  //上凸包while(m > k && Cross(ch[m-2] , ch[m-1] , p[i]) < 0) m--;ch[m++] = p[i];}if(n > 1) m--;return m;
}
Point p[maxn] , ch[maxn];
int main()
{int n;while(cin >> n){for(int i = 0; i < n; i++) cin >> p[i].x >> p[i].y;int m = Andrew(p , n , ch); ///求凸包///旋转卡壳法int ans = 0;for(int i = 0; i < m; i++){int q = 1;for(int j = i + 1; j < m; j++){while(Cross(ch[i],ch[j],ch[q+1]) > Cross(ch[i],ch[j],ch[q]))q = (q + 1) % m;ans = max(ans , Cross(ch[i],ch[j],ch[q]));}}//cout << fixed << setprecision(2) << ans / 2.0 << endl;printf("%.2lf\n",ans/2.0);}return 0;
}

hdu2202 凸包+旋转卡壳相关推荐

  1. POJ 2187 凸包+旋转卡壳

    思路: 求个凸包 旋转卡壳一下 就求出来最远点对了 注意共线情况 也就是说   凸包如果有一堆点共线保留端点即可 //By SiriusRen #include <cmath> #incl ...

  2. POJ - 2187 Beauty Contest (求距离最远点对-凸包+旋转卡壳/枚举 (旋转卡壳学习))

    链接:https://vjudge.net/problem/POJ-2187 题意:求求距离最远点对. 思路:肯定为凸包上的点,可枚举,也可根据凸包性质旋转卡壳求对踵点. 参考博客: https:// ...

  3. 【BZOJ1185】【HNOI2007】最小矩形覆盖(凸包+旋转卡壳)

    传送门 题意:求最小矩阵覆盖 有这样一个结论:矩阵一定有一条边在凸包上(不会证) 那可以枚举每条边 同时旋转卡壳 只是这时不只维护一个对踵点对,同时在左右侧再维护一个最远点 可以发现左右最远点一定是和 ...

  4. Beauty Contest(凸包 + 旋转卡壳(模板))

    Beauty Contest 直接跑一个凸包,然后跑一跑旋转卡壳,求最大值就行了. /*Author : lifehappy */ #include <cstdio> #include & ...

  5. 凸包旋转卡壳(andrew)

    题目链接 如图计算上凸包时判断C1,C2,C3C_1,C_2,C_3C1​,C2​,C3​显然C3C_3C3​是经过A,BA,BA,B的上凸包 可以发现只需要通过A,BA,BA,B即可判断,通过观察可 ...

  6. bzoj1069: [SCOI2007]最大土地面积 凸包+旋转卡壳求最大四边形面积

    在某块平面土地上有N个点,你可以选择其中的任意四个点,将这片土地围起来,当然,你希望这四个点围成的多边形面积最大. 题解:先求出凸包,O(n)枚举旋转卡壳,O(n)枚举另一个点,求最大四边形面积 /* ...

  7. Gym - 102460L Largest Quadrilateral(几何-凸包+旋转卡壳求最大的四边形面积)

    题目链接:点击查看 题目大意:在笛卡尔坐标系上给出 n 个点,要求选出四个点,使得组成的四边形面积最大,求出这个最大的面积,注意此处组成的四边形不是严格意义上的四边形,只需要选四个点就行 题目分析:首 ...

  8. 【BZOJ1069】【SCOI2007】—最大土地面积(凸包+旋转卡壳)

    传送门 考虑枚举任意222个点,那么只需要枚举第二个点的时候旋转卡壳就可以O(n)O(n)O(n)得到最远点对了 #include<bits/stdc++.h> using namespa ...

  9. 凸包问题--旋转卡壳

    前情提要: 1978年,M.I.Shamos在论文<Computational Ceometry>中介绍了一种寻找凸多边形直径的线性算法. Shamos的算法就像绕着多边形旋转一对卡壳,因 ...

最新文章

  1. 常用的Percona-Toolkit工具
  2. RDKit | 基于RDKit的氨基酸序列转换为SMILES
  3. redis安装后提示权限问题ERR operation not permitted
  4. 在性能测试时使用nmon进行监控服务器性能
  5. 大数据聚类分析用于预测_多模态数据中的非负矩阵分解用于分割和标签预测
  6. 我的代码很好,不需要写注释
  7. git gui怎么拉取项目代码_Git可视化极简易教程 — Git GUI使用方法
  8. 360浏览器急速模式_关于规范电子税务局浏览器要求及设置的通知
  9. XMPP的简介和基本概念
  10. PHP聚合直播盒子网站源码聚合全网直播
  11. pinphp3.0后台系统权限管理的bug
  12. TensorFlow Probability概率编程-时序模型
  13. 前端更新需要清空浏览器缓存_浏览器缓存机制分析及前端缓存清理
  14. Spark中RDD的sortBy排序的5种实现方法
  15. ICC2里面多进程任务
  16. C/C++中的日期和时间
  17. 相对论中光速恒定,时间可变的原理
  18. 真无线蓝牙耳机哪个延迟最低?低延迟蓝牙耳机推荐
  19. python获取网页内容 不打开_网页抓取python不返回任何内容
  20. Teradata SQL 日期

热门文章

  1. java实践7索引之Hash索引、位图索引、倒排索引原理
  2. 《画解数据结构》(0 - 1)- 算法时间复杂度
  3. 《SolidWorks 2012中文版从入门到精通》一6.3 零件的特征管理
  4. EmguCv多边形包围
  5. 华清远见学习—“进制之间的转换”
  6. linux下搜狗打字软件下载,搜狗输入法Linux
  7. 同时安装两个Tomcat配置教程(Win10)
  8. prototype详解
  9. 无线网络代理服务器广东,广东运营商推免费WiFi上网服务
  10. 前端必会:CDN加速原理