\(\color{#0066ff}{ 题目描述 }\)

兔子们决定在自己的城堡里安排一些士兵进行防守。

给出 n 个点的坐标,和城堡里一个圆心在原点的圆形的障碍,兔子们希望从中选出 k 个兔子,使得它们两两所在的直线都不与圆相交。

兔子们希望知道最多能选出多少兔子。

\(\color{#0066ff}{输入格式}\)

第一行两个整数 N 和 R, 表示兔子的个数和圆的半径接下来 N 行,每行两个整数 xi 和 yi ,表示第 i 只兔子的坐标

保证每只兔子都严格在障碍外部,且两两的所在的直线不与圆相切。

\(\color{#0066ff}{输出格式}\)

输出一行一个整数, 表示最多能选出多少兔子

\(\color{#0066ff}{输入样例}\)

6 3
0 6
-7 -4
-3 -2
7 -5
-2 3
8 -3

\(\color{#0066ff}{输出样例}\)

4

\(\color{#0066ff}{数据范围与提示}\)

选择第 1, 2, 6, 4 只兔子即可。

  • 对于 10% 的测试数据, 1 ≤ n ≤ 20.
  • 对于 30% 的测试数据, 1 ≤ n ≤ 100.
  • 对于 100% 的测试数据, 1 ≤ n ≤ 2000; 1 ≤ R; xi; yi ≤ 5000.

\(\color{#0066ff}{ 题解 }\)

过每一个点做圆的两条切线,每个点占据了圆上的一段劣弧

不难发现,两个点的连线与圆有交,当且仅当两段劣弧不相离且互补包含,即普通的相交

于是我们开始想办法获得这个劣弧

我们该怎么存储这种东西呢

考虑把环断开,以极角作为链上的数值,强制让线段范围为\([-\pi,\pi]\),对于不在这个范围上的端点,可以直接\(+-2\pi\),显然没影响

那么怎么获得这两个端点值(角度)呢

∠AOB=∠AOC, 因此只要让极角∠AOD加减∠AOB即可获得端点值

然后我们把所有区间按左端点排序

然后枚举每个区间作为选择的起始区间,枚举之后选择的区间,那之后选择的区间要满足左端点小于起始区间右端点,右端点大于起始区间右端点,这样才是相交

我们把这些区间放在数组里,左端点是递增的且一定小于起始区间右端点

那么可以发现,最多选择的数量就是这些区间右端点的最长上升子序列!

于是\(O(n^2logn)\)即可解决本题

#include<bits/stdc++.h>
#define LL long long
LL in() {
char ch; LL x = 0, f = 1;
while(!isdigit(ch = getchar()))(ch == '-') && (f = -f);
for(x = ch ^ 48; isdigit(ch = getchar()); x = (x << 1) + (x << 3) + (ch ^ 48));
return x * f;
}
const int maxn = 2050;
const double pi = acos(-1);
using std::pair;
using std::make_pair;
int n;
double R;
pair<double, double> e[maxn];
int num, ans;
double f[maxn], t[maxn];
int query() {
int len;
if(!num) return 0;
f[len = 1] = t[1];
for(int i = 2; i <= num; i++) {
if(t[i] > f[len]) f[++len] = t[i];
else *std::upper_bound(f + 1, f + len + 1, t[i]) = t[i];
}
return len;
}
int main() {
n = in(), R = in();
double x, y;
for(int i = 1; i <= n; i++) {
x = in(), y = in();
double bt = atan2(y, x);
double len = sqrt(x * x + y * y);
double af = acos(R / len);
x = bt - af, y = bt + af;
while(x <= -pi) x += 2.0 * pi;
while(y > pi) y -= 2.0 * pi;
if(x > y) std::swap(x, y);
e[i] = make_pair(x, y);
}
std::sort(e + 1, e + n + 1);
for(int i = 1; i <= n; i++) {
num = 0;
for(int j = i + 1; j <= n; j++)
if(e[j].first <= e[i].second && e[j].second >= e[i].second)
t[++num] = e[j].second;
ans = std::max(ans, query());
}
printf("%d", ans + 1);
return 0;
}

P3897 [湖南集训]Crazy Rabbit的更多相关文章

  1. 主席树 || 可持久化线段树 || BZOJ 3653: 谈笑风生 || Luogu P3899 [湖南集训]谈笑风生

    题面:P3899 [湖南集训]谈笑风生 题解: 我很喜欢这道题. 因为A是给定的,所以实质是求二元组的个数.我们以A(即给定的P)作为基点寻找答案,那么情况分两类.一种是B为A的父亲,另一种是A为B的 ...

  2. P3900 [湖南集训]图样图森破

    P3900 [湖南集训]图样图森破 链接 分析: 感觉像个暴力. 可以枚举回文串的回文中心,即枚举一个串,枚举一个串的位置作为回文中心,然后求出这个串内的回文串的长度. 此时如果回文串两端都没有到这个 ...

  3. 【BZOJ4660】Crazy Rabbit 结论+DP

    [BZOJ4660]Crazy Rabbit Description 兔子们决定在自己的城堡里安排一些士兵进行防守.给出 n 个点的坐标,和城堡里一个圆心在原点的圆形的障碍,兔子们希望从中选出 k 个 ...

  4. 三倍经验——bzoj3663、4660、4206 Crazy Rabbit/最大团

    题目描述: 3663 4660 4206 题解: 第一眼:不成立的互相连边,然后用网络流求解无向图最小点覆盖! 好吧我不会. 正解: 每个点对应圆上的一段圆弧,长这样: 设对应圆弧$(l,r)$. 若 ...

  5. bzoj 3653 [湖南集训]谈笑风生

    题目描述 设 T 为一棵有根树,我们做如下的定义: • 设 a 和 b 为 T 中的两个不同节点.如果 a 是 b 的祖先,那么称"a 比 b 不知道高明到哪里去了". • 设 a ...

  6. luogu P3899 [湖南集训]谈笑风生

    传送门 nmyzd,mgdhls,bnmbzdgdnlql,a,wgttxfs 对于一个点\(a\),点\(b\)只有可能是他的祖先或者在\(a\)子树里 如果点\(b\)是\(a\)祖先,那么答案为 ...

  7. 洛谷P3899 [湖南集训]谈笑风生(线段树合并)

    题意 题目链接 Sol 线段树合并板子题,目前我看到两种写法,分别是这样的. 前一种每次需要新建一个节点,空间是\(O(4nlogn)\) 后者不需要新建,空间是\(O(nlogn)\)(面向数据算空 ...

  8. P3899 [湖南集训]谈笑风生

    题目链接 https://www.lydsy.com/JudgeOnline/problem.php?id=3653 https://www.luogu.org/problemnew/show/P38 ...

  9. bzoj 4660 Crazy Rabbit——LIS解决“相交”限制的思想

    题目:https://www.lydsy.com/JudgeOnline/problem.php?id=4660 想到一个点可以用它与圆的两个切点表示.并想到可以把切点极角排序,那么就变成环上的一些区 ...

随机推荐

  1. $timeout()定时器

    非常不幸的一点是,人们似乎常常将AngularJS中的$timeOut()函数看做是一个内置的.无须在意的函数.但是,如果你忘记了$timeOut()的回调函数将会造成非常不好的影响,你可能会因此遇到 ...

  2. Windows 常见进程

    alg.exe描述: alg.exe是Windows系统的一个重要进程,它的功能是用来处理 Internet 连接共享及防火墙,最好不要结束这个进程.taskmgr.exe描述: Windowsxp ...

  3. 问题:c# json解析;结果:c# 解析JSON的几种办法

    c# 解析JSON的几种办法 欲成为海洋大师,必知晓海中每一滴水的真名. 刚开始只是想找一个转换JSON数组的方法,结果在MSDN翻到一大把. 搜索过程中免不了碰到一大堆名词:WCF => Da ...

  4. Android Studio Build APK没有报错,但是Generate signed apk报错

    有时候 ,我们在调试APK,直接Build是可以正常生成,没有报错,但是当我们将自己的签名文件加上去,就会报错.一般情况下,我们可以在build.gradle中的android{}里面添加一个东西 l ...

  5. css之content

    content 属性与 :before 及 :after 伪元素配合使用,来插入生成内容.该属性用于定义元素之前或之后放置的生成内容.默认地,这往往是行内内容,不过该内容创建的框类型可以用属性 dis ...

  6. html乱码原因与网页乱码解决方法

    造成html网页乱码原因主要是html源代码内中文字内容与html编码不同造成.但无论是哪种情况造成乱码在网页开始时候都需要设置网页编码. charset编码设置 html网页乱码效果截图 一.乱码造 ...

  7. 如何选择RDBMS关系型数据库和Nosql非关系型数据库?

    RDBMS关系型数据库和Nosql非关系型数据库区别: 一.RDBMS是关系型数据库模式: 1.二维模式,由行列组成. 2.非常强调事务原子性,例如用户提出一个请求,DB完整的去执行,如果报错就全部回 ...

  8. Linux 下安装redis

    记录一下linux下的安装步骤,还是比较复杂的 1. 下载redis-2.8.19.tar.gz: ftp传到linux01上: 解压: tar –zxvf redis-2.8.19.tar.gz 2 ...

  9. strstr()查找函数,strchr(),strrchr(),stristr()/strpos(),strrpos()查找字符串位置

    在一个较长的字符串这查找匹配的字符串或字符,其中strstr()和strchr()是完全一样的. 例: echo strstr('why always you','you'); 输出: you 如果为 ...

  10. gearman安装问题总结

    解决configure: WARNING: You will need re2c 0.13.4 or later if you want to regenerate PHP parsers. yum ...