hdu2202 凸包+旋转卡壳
点击打开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 凸包+旋转卡壳相关推荐
- POJ 2187 凸包+旋转卡壳
思路: 求个凸包 旋转卡壳一下 就求出来最远点对了 注意共线情况 也就是说 凸包如果有一堆点共线保留端点即可 //By SiriusRen #include <cmath> #incl ...
- POJ - 2187 Beauty Contest (求距离最远点对-凸包+旋转卡壳/枚举 (旋转卡壳学习))
链接:https://vjudge.net/problem/POJ-2187 题意:求求距离最远点对. 思路:肯定为凸包上的点,可枚举,也可根据凸包性质旋转卡壳求对踵点. 参考博客: https:// ...
- 【BZOJ1185】【HNOI2007】最小矩形覆盖(凸包+旋转卡壳)
传送门 题意:求最小矩阵覆盖 有这样一个结论:矩阵一定有一条边在凸包上(不会证) 那可以枚举每条边 同时旋转卡壳 只是这时不只维护一个对踵点对,同时在左右侧再维护一个最远点 可以发现左右最远点一定是和 ...
- Beauty Contest(凸包 + 旋转卡壳(模板))
Beauty Contest 直接跑一个凸包,然后跑一跑旋转卡壳,求最大值就行了. /*Author : lifehappy */ #include <cstdio> #include & ...
- 凸包旋转卡壳(andrew)
题目链接 如图计算上凸包时判断C1,C2,C3C_1,C_2,C_3C1,C2,C3显然C3C_3C3是经过A,BA,BA,B的上凸包 可以发现只需要通过A,BA,BA,B即可判断,通过观察可 ...
- bzoj1069: [SCOI2007]最大土地面积 凸包+旋转卡壳求最大四边形面积
在某块平面土地上有N个点,你可以选择其中的任意四个点,将这片土地围起来,当然,你希望这四个点围成的多边形面积最大. 题解:先求出凸包,O(n)枚举旋转卡壳,O(n)枚举另一个点,求最大四边形面积 /* ...
- Gym - 102460L Largest Quadrilateral(几何-凸包+旋转卡壳求最大的四边形面积)
题目链接:点击查看 题目大意:在笛卡尔坐标系上给出 n 个点,要求选出四个点,使得组成的四边形面积最大,求出这个最大的面积,注意此处组成的四边形不是严格意义上的四边形,只需要选四个点就行 题目分析:首 ...
- 【BZOJ1069】【SCOI2007】—最大土地面积(凸包+旋转卡壳)
传送门 考虑枚举任意222个点,那么只需要枚举第二个点的时候旋转卡壳就可以O(n)O(n)O(n)得到最远点对了 #include<bits/stdc++.h> using namespa ...
- 凸包问题--旋转卡壳
前情提要: 1978年,M.I.Shamos在论文<Computational Ceometry>中介绍了一种寻找凸多边形直径的线性算法. Shamos的算法就像绕着多边形旋转一对卡壳,因 ...
最新文章
- 常用的Percona-Toolkit工具
- RDKit | 基于RDKit的氨基酸序列转换为SMILES
- redis安装后提示权限问题ERR operation not permitted
- 在性能测试时使用nmon进行监控服务器性能
- 大数据聚类分析用于预测_多模态数据中的非负矩阵分解用于分割和标签预测
- 我的代码很好,不需要写注释
- git gui怎么拉取项目代码_Git可视化极简易教程 — Git GUI使用方法
- 360浏览器急速模式_关于规范电子税务局浏览器要求及设置的通知
- XMPP的简介和基本概念
- PHP聚合直播盒子网站源码聚合全网直播
- pinphp3.0后台系统权限管理的bug
- TensorFlow Probability概率编程-时序模型
- 前端更新需要清空浏览器缓存_浏览器缓存机制分析及前端缓存清理
- Spark中RDD的sortBy排序的5种实现方法
- ICC2里面多进程任务
- C/C++中的日期和时间
- 相对论中光速恒定,时间可变的原理
- 真无线蓝牙耳机哪个延迟最低?低延迟蓝牙耳机推荐
- python获取网页内容 不打开_网页抓取python不返回任何内容
- Teradata SQL 日期