题面

传送门

题解

以下记\(S_i=\{1,2,3,...,i\}\)

我们先用凸包+旋转卡壳求出直径的长度,并记直径的两个端点为\(i,j\)(如果有多条直径随机取两个端点)

因为这个序列被\(random\_shuffle\)过,有\(E(\max(i,j))=O({2\over 3}n)\),即\(\max(i,j)\)的较大值的期望是\(O({2\over 3}n)\)。证明如下

\[\begin{aligned}
E(\max(i,j))
&={1\over n^2}\sum_{k=1}^nk\times (2k-1)\\
&={1\over n^2}\left(2\sum_{k=1}^nk^2-\sum_{k=1}^nk\right)\\
&={1\over n^2}\left({2n(n+1)(2n+1)\over 6}-{3n(n+1)\over 6}\right)\\
&={1\over n^2}\left({4n^3+3n^2-n\over 6}\right)\\
&=O({2\over 3}n)\\
\end{aligned}
\]

假设\(j>i\),那么对于\(S_{j+1},S_{j+2},...,S_n\),它们的答案都一样。然后对于剩下的继续做下去就可以了

我们来分析一下这玩意儿的时间复杂度是多少

\[T(n)=T({2\over 3}n)+O(n\log n)
\]

\[T(1)=O(1)
\]

嗯……我并不会主定理所以算不太动……不过我们可以考虑一个形如\(n+{2\over 3}n+{4\over 9}n+...+1\)的东西的求和,为了方便干脆直接将它写成无限求和的形式,那么可知它等于\(3n\),即\(O(n)\)。那么这里也类似,所以我们完全没有道理地证明了\(T(n)=O(n\log n)\)

话说不知道如果序列不\(random\_shufle\)有没有办法搞……

//minamoto
#include<bits/stdc++.h>
#define R register
#define inf 0x3f3f3f3f
#define ll long long
#define pi pair<int,int>
#define fi first
#define se second
#define inline __inline__ __attribute__((always_inline))
#define fp(i,a,b) for(R int i=(a),I=(b)+1;i<I;++i)
#define fd(i,a,b) for(R int i=(a),I=(b)-1;i>I;--i)
#define go(u) for(int i=head[u],v=e[i].v;i;i=e[i].nx,v=e[i].v)
template<class T>inline bool cmax(T&a,const T&b){return a<b?a=b,1:0;}
using namespace std;
char buf[1<<21],*p1=buf,*p2=buf;
inline char getc(){return p1==p2&&(p2=(p1=buf)+fread(buf,1,1<<21,stdin),p1==p2)?EOF:*p1++;}
int read(){
R int res,f=1;R char ch;
while((ch=getc())>'9'||ch<'0')(ch=='-')&&(f=-1);
for(res=ch-'0';(ch=getc())>='0'&&ch<='9';res=res*10+ch-'0');
return res*f;
}
char sr[1<<21],z[20];int K=-1,Z=0;
inline void Ot(){fwrite(sr,1,K+1,stdout),K=-1;}
void print(R ll x){
if(K>1<<20)Ot();if(x<0)sr[++K]='-',x=-x;
while(z[++Z]=x%10+48,x/=10);
while(sr[++K]=z[Z],--Z);sr[++K]='\n';
}
const int N=7.5e5+5;
struct Point{
int x,y,id;
inline Point(){}
inline Point(R int xx,R int yy):x(xx),y(yy){}
inline Point operator +(const Point &b)const{return Point(x+b.x,y+b.y);}
inline Point operator -(const Point &b)const{return Point(x-b.x,y-b.y);}
inline ll operator *(const Point &b)const{return 1ll*x*b.y-1ll*y*b.x;}
inline ll norm()const{return 1ll*x*x+1ll*y*y;}
}q[N],p[N];int top,n;ll res,ans[N];pi qwq;
bool cmp(const Point &a,const Point &b){
R ll k=(a-p[0])*(b-p[0]);
return k?k>0:(a-p[0]).norm()<(b-p[0]).norm();
}
void solve(int r){
int k=0;p[0]=Point(inf,inf),top=0;
fp(i,1,r){
p[i]=q[i],p[i].id=i;
if(p[i].x<p[0].x||p[i].x==p[0].x&&p[i].y<p[0].y)k=i,p[0]=p[i];
}
swap(p[1],p[k]);
sort(p+2,p+1+r,cmp);
fp(i,1,r){
while(top>1&&(p[i]-p[top-1])*(p[top]-p[top-1])>=0)--top;
p[++top]=p[i];
}
p[top+1]=p[1];
res=0,qwq=make_pair(0,0);
for(R int i=1,j=2;i<=top;++i){
while((p[j+1]-p[i]).norm()>(p[j]-p[i]).norm())j=j%top+1;
if(cmax(res,(p[j]-p[i]).norm()))qwq=make_pair(p[i].id,p[j].id);
if(cmax(res,(p[j+1]-p[i+1]).norm()))qwq=make_pair(p[i+1].id,p[j+1].id);
}
if(qwq.fi>qwq.se)swap(qwq.fi,qwq.se);
}
int main(){
// freopen("testdata.in","r",stdin);
n=read();
fp(i,1,n)q[i].x=read(),q[i].y=read();
for(R int r=n;r!=1;r=qwq.se-1){
solve(r);
fp(i,qwq.se,r)ans[i]=res;
}
ans[1]=0;
fp(i,1,n)print(ans[i]);
return Ot(),0;
}

Code Chef GEOCHEAT(凸包+旋转卡壳+随机化)的更多相关文章

  1. [USACO2003][poj2187]Beauty Contest(凸包+旋转卡壳)

    http://poj.org/problem?id=2187 题意:老题了,求平面内最远点对(让本渣默默想到了悲剧的AHOI2012……) 分析: nlogn的凸包+旋转卡壳 附:http://www ...

  2. UVA 4728 Squares(凸包+旋转卡壳)

    题目链接:http://acm.hust.edu.cn/vjudge/problem/viewProblem.action?id=17267 [思路] 凸包+旋转卡壳 求出凸包,用旋转卡壳算出凸包的直 ...

  3. poj 2079 Triangle (二维凸包旋转卡壳)

    Triangle Time Limit: 3000MS   Memory Limit: 30000KB   64bit IO Format: %I64d & %I64u Submit Stat ...

  4. poj 2187 Beauty Contest(二维凸包旋转卡壳)

    D - Beauty Contest Time Limit:3000MS     Memory Limit:65536KB     64bit IO Format:%I64d & %I64u ...

  5. POJ 2187 凸包+旋转卡壳

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

  6. 【BZOJ-1069】最大土地面积 计算几何 + 凸包 + 旋转卡壳

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

  7. [luogu1452]Beauty Contest【凸包+旋转卡壳】

    题目大意 求出平面最远点对距离的平方. 分析 此题我wa了好久,第一是凸包写错了,后面又是旋转卡壳写错了..自闭3s. 题解应该是旋转卡壳,但是有人用随机化乱搞过掉了Orz. 讲讲正解. 我们先求出所 ...

  8. [HNOI2007][BZOJ1185] 最小矩形覆盖 [凸包+旋转卡壳]

    题面 BZOJ题面 前置芝士 建议先学习向量相关的计算几何基础 计算几何基础戳这里 思路 用这道题学习一下凸包和旋转卡壳 首先是凸包部分 凸包 求凸包用的算法是graham算法 算法流程如下: 找到$ ...

  9. BZOJ 1185 [HNOI2007]最小矩形覆盖:凸包 + 旋转卡壳

    题目链接:https://www.lydsy.com/JudgeOnline/problem.php?id=1185 题意: 给出二维平面上的n个点,问你将所有点覆盖的最小矩形面积. 题解: 先找出凸 ...

随机推荐

  1. MySQL主从复制备份

    前言 数据库实时备份的需求很常见,MySQL本身提供了 Replication 机制,摘译官方介绍如下: MySQL Replication 可以将一个主数据库中的数据同步到一个或多个从数据库中.并且 ...

  2. DirectFB编程

    一.简介 DirectFB是一个轻量级的提供硬件图形加速,输入设备处理和抽象的图形库,它集成了支持半透明的视窗系统以及在LinuxFramebuffer驱动之上的多层显示.它是一个用软件封装当前硬件无 ...

  3. [SoapUI] Command-Line Arguments

    https://support.smartbear.com/readyapi/docs/soapui/running/automating/cli.html Use the test runner t ...

  4. java.text.SimpleDateFormat的使用

    SimpleDateFormat 是一个以国别敏感的方式格式化和分析数据的具体类. 它允许格式化 (date -> text).语法分析 (text -> date)和标准化. Simpl ...

  5. 创建 maven web 项目时 ,更改 为 Dynamic web module 为 3.0 时 项目报错

    更改 项目 project facets 将 dynamic web module  改为 3.0 ,如果 java 的 版本 为 1.7 以下 ,项目会出现 叉 , 原因是  web 3.0  要和 ...

  6. 想到的regular方法果然已经被sklearn实现了就是L1和L2组合rugular

  7. 做SEO都需要具备哪些方面的知识

    做seo需要了解的基本知识有利于seo工作的进行 一.了解搜索引擎的工作原理 搜索引擎的基本工作原理包括如下三个过程: 1.首先在互联网中发现.搜集网页信息; 2.同时对信息进行提取和组织建立索引库; ...

  8. hdu-1026(bfs+优先队列)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1026 题意:输入n,m和一个n*m的矩阵, .表示通路: x表示墙: n表示有一个怪物,消灭它需要n个 ...

  9. HDU 1009 FatMouse' Trade (贪心算法)

    题意:就是老鼠要用猫粮换粮食,第i个房间一些东西,要用东西去换,可以不全换.问给定的猫粮最多能换多少粮食. 析:贪心算法.我们先算出来每个房间物品的平均价格是多少,肯定越低越好,并且如果能全换就全换, ...

  10. 201709013工作日记--static理解 && abstract

    1.关于viewHolder设置成static的讨论 一般情况下是尽量不要使用static关键字,因为static一旦有引用变量指向了变量,使用完毕后而没有设置null,就会造成内存泄露,而且很难排查 ...