BZOJ 4206: 最大团
4206: 最大团
Time Limit: 10 Sec Memory Limit: 256 MB
Submit: 91 Solved: 36
[Submit][Status][Discuss]
Description
Input
Output
Sample Input
0 6
-7 -4
-3 -2
7 -5
-2 3
8 -3
Sample Output
HINT
对于100%的数据,1≤N≤2000,|xi|,|yi|,R≤5000
Source
分析:
考虑什么样子的两个点确定的直线是合法的...
我们从每个点向圆做两条切线...这两条切线之间有一段弧...如果两个点确定的直线可以选择,当且仅当这两个点对应的弧相交并且不包含...
现在我们把圆切开展成一条线段,我们把弧覆盖这个切点的点的弧取反...并不会影响答案...
现在我们得到了若干区间,我们要找的是包含区间最多的合法序列使得其满足:
$l_1<l_2<l_3<......<l_n<r_1<r_2<r_3<......<r_n$
现在我们枚举第一个区间是什么,这样我们就确定了可选的$l_i$的范围,我们把可选的区间提取出来,按照$l$排序,然后求$r$的最长上升子序列就好了...
代码:
#include<algorithm>
#include<iostream>
#include<cstring>
#include<cstdio>
#include<cmath>
//by NeighThorn
using namespace std; const int maxn=2000+5;
const double pi=acos(-1.0),inf=1e8; int n,ans,cas;
double r,tmp[maxn],posx[maxn],posy[maxn]; struct M{ double x,y;
int del; inline void init(void){
del=0;
} friend bool operator < (M a,M b){
if(a.del!=b.del) return a.del<b.del;
if(a.x!=b.x) return a.x<b.x;
if(a.y!=b.y) return a.y<b.y;
} }no[maxn]; signed main(void){
scanf("%d%lf",&n,&r);
for(int i=1;i<=n;i++)
scanf("%lf%lf",&posx[i],&posy[i]),no[i].init();
for(int i=1,x,y;i<=n;i++){
double len=sqrt(posx[i]*posx[i]+posy[i]*posy[i]);
if(len<=r){
no[i].del=1;break;
}
double ang1=atan2(posy[i],posx[i]),ang2=acos(r/len);
no[i].x=ang1-ang2;no[i].y=ang1+ang2;
if(no[i].y>pi) no[i].y-=2*pi,swap(no[i].x,no[i].y);
if(no[i].x<-pi) no[i].x+=2*pi,swap(no[i].x,no[i].y);
}
sort(no+1,no+n+1);ans=0;
while(no[n].del==1) n--;
for(int i=1;i<=n;i++){
double x=no[i].x,y=no[i].y;
for(int j=0;j<n;j++) tmp[j]=inf;
for(int j=i+1;j<=n&&no[j].x<y;j++){
if(no[j].y>no[i].y)
*lower_bound(tmp,tmp+n,no[j].y)=no[j].y;
}
ans=max(ans,(int)(lower_bound(tmp,tmp+n,inf)-tmp)+1);
}
printf("%d\n",ans);
return 0;
}
By NeighThorn
BZOJ 4206: 最大团的更多相关文章
- bzoj 4206 最大团 几何+lis
最大团 Time Limit: 10 Sec Memory Limit: 256 MBSubmit: 142 Solved: 65[Submit][Status][Discuss] Descrip ...
- bzoj AC倒序
Search GO 说明:输入题号直接进入相应题目,如需搜索含数字的题目,请在关键词前加单引号 Problem ID Title Source AC Submit Y 1000 A+B Problem ...
- bzoj 3632: 外太空旅行 最大团
3632: 外太空旅行 Time Limit: 5 Sec Memory Limit: 128 MBSubmit: 389 Solved: 129[Submit][Status] Descript ...
- 【BZOJ 2744】 2744: [HEOI2012]朋友圈 (最大团,二分图匹配,构图)
2744: [HEOI2012]朋友圈 Description 在很久很久以前,曾经有两个国家和睦相处,无忧无虑的生活着.一年一度的评比大会开始了,作为和平的两国,一个朋友圈数量最多的永远都是最值得他 ...
- BZOJ 3632 外太空旅行(最大团)
[题目链接] http://www.lydsy.com/JudgeOnline/problem.php?id=3632 [题目大意] 求图中的最大团. [题解] 最大团问题是npc问题,因此可以考虑随 ...
- BZOJ - 2744 朋友圈 (二分图上的最大团)
[题目大意] 在很久很久以前,曾经有两个国家和睦相处,无忧无虑的生活着.一年一度的评比大会开始了,作为和平的两国,一个朋友圈数量最多的永远都是最值得他人的尊敬,所以现在就是需要你求朋友圈的最大数目.两 ...
- 三倍经验——bzoj3663、4660、4206 Crazy Rabbit/最大团
题目描述: 3663 4660 4206 题解: 第一眼:不成立的互相连边,然后用网络流求解无向图最小点覆盖! 好吧我不会. 正解: 每个点对应圆上的一段圆弧,长这样: 设对应圆弧$(l,r)$. 若 ...
- BZOJ平推计划
学习VFK大神推BZOJ,记录一下学习的东西 1004: burnside:一个置换群的等价计数=(每个置换的置换后等价情况数)/置换总数,每个置换的置换后等价情况数就是置换后没变的数 模意义下的除法 ...
- [BZOJ 1006] [HNOI2008] 神奇的国度 【弦图最小染色】
题目链接: BZOJ - 1006 题目分析 这道题是一个弦图最小染色数的裸的模型. 弦图的最小染色求法,先求出弦图的完美消除序列(MCS算法),再按照完美消除序列,从后向前倒着,给每个点染能染的最小 ...
随机推荐
- P1332 血色先锋队
P1332 血色先锋队 题目描述 巫妖王的天灾军团终于卷土重来,血色十字军组织了一支先锋军前往诺森德大陆对抗天灾军团,以及一切沾有亡灵气息的生物.孤立于联盟和部落的血色先锋军很快就遭到了天灾军团的重重 ...
- RAID(冗余硬盘阵列)
一. RAID定义 RAID( Redundant Array of Independent Disk 独立冗余磁盘阵列 )技术是加州大学伯克利分校1987年提出,最初是为了组合小的廉价磁盘来代替大的 ...
- Git初步
在多人参与开发的项目中,版本控制工具是必须的,网上有很多不错的教程,能简单使用就ok了,粘几篇教程,方便学习 首先我们要了解一些基本的概念,此处简单描述一下 (1)集中式版本控制系统: CVS.SVN ...
- 利用LD_PRELOAD进行hook
原文地址:http://hbprotoss.github.io/posts/li-yong-ld_preloadjin-xing-hook.html 好久没玩hook这种猥琐的东西里,今天在Linux ...
- tomcat 异常
Removing obsolete files from server... Could not clean server of obsolete files: null java.lang.Null ...
- 常用的python模块及安装方法
adodb:我们领导推荐的数据库连接组件 bsddb3:BerkeleyDB的连接组件Cheetah-1.0:我比较喜欢这个版本的cheetahcherrypy:一个WEB frameworkctyp ...
- CodeBlocks 3 使用设置
使用MingW作为CB的默认编译器和wxWidgets进行编程,当然需要好好配置一番,因为mingw在windows下用起来着实没有win32原生态程序运行快,也没有他小,好处是借助wxwidgets ...
- Halcon环境搭建
1.Visual Studio 2017安装教程 2.Qt5.9安装教程 3.VS2017中Qt插件安装教程
- git instaweb 500 error
在arch 系统中安装perl-cgi包. 在deiban中参考:https://git-scm.com/book/zh/v2/%E6%9C%8D%E5%8A%A1%E5%99%A8%E4%B8%8A ...
- HDU 3699 A hard Aoshu Problem(暴力枚举)(2010 Asia Fuzhou Regional Contest)
Description Math Olympiad is called “Aoshu” in China. Aoshu is very popular in elementary schools. N ...