CF Hello 2020 E.New Year and Castle Construction
E.New Year and Castle Construction
题意
给定n个点,对于每个点\(p\),求出4-point 子集(该子集有四个点,并且围成的圈包含\(p\))的个数
数据给的点中没有三点共线的情况
这个题的题意并不是很好理解,补题过后还发现自己理解的题解是有问题的。
分析
四个点围成一个圈,第5个点在其中。所以总方案数为\(n*C_{n-1}^4\),枚举中间那个点,然后从剩余的(n-1)个点中选剩余的四个点。
考虑\(n^2\)的做法,正向枚举所有方案中可行的方案并不是很合适,因为要考虑更大的子集的情况,所以反向枚举。
不合法的方案:其他的四个点并不能包含点\(p\)。枚举这四个点中的其中一个点\(q\),计算取剩余3个点的方案数。考虑\(p\)与\(q\)连成的直线,可以从这条直线某一侧取出三个点,可以发现这样的组合一定不会使得四个点构成的圈包含\(p\)。
如何不重不漏的删除所有不合法的方案?对于每个\(p\),\(q\)作为四个点中,与\(p\)连线斜率最小的那个点,然后在这样的基础上,只能从\(pq\)连线一侧拿另外三个点。可以想到这样的方案对于\(p\)来讲是没有重复的。而\(p\)的枚举又是独立的,所以可以补充不漏的删除所有方案。
const int N = 3005;
long double x[N],y[N];
int main()
{
int n;scanf("%d",&n);
for(int i=1;i<=n;i++){
cin >> x[i] >> y[i];
}
ll res = 1ll * n * (n-1) * (n-2) * (n-3) * (n-4) / 24;
long double pi = acos(-1.0L);
for(int i=1;i<=n;i++){
vector<long double> v;
for(int j=1;j<=n;j++){
if(i == j)continue;
v.push_back(atan2(y[j]-y[i],x[j]-x[i]));
}
sort(v.begin(),v.end());
int m = n-1,index = 0;
for(int j=0;j<m;j++){
while(index < j + m){
long double ang = v[index%m] - v[j];
if(ang < 0) ang += 2 * pi;
if(ang < pi)index ++;
else break;
}
ll cnt = index - j - 1;
res -= 1ll * cnt * (cnt - 1) * (cnt - 2) / 6;
}
}
cout << res << endl;
return 0;
}
参考链接
B站up主:https://www.bilibili.com/video/av82161298?p=411
ps:题解有些许啰嗦,up主视频中讲解的很清楚,然后我对这个解法的正确性进行了一些额外的思考,表达能力欠佳,如果读者发现描述中有不准确或者不理解的地方,烦请在下面留言,谢谢!在最后非常感谢B站up主qscqesze的讲解。
CF Hello 2020 E.New Year and Castle Construction的更多相关文章
- codeforces 1284E. New Year and Castle Construction(极角排序+扫描枚举)
链接:https://codeforces.com/problemset/problem/1284/E 题意:平面上有n个点,问你存在多少组四个点围成的四边形 严格包围某个点P的情况.不存在三点共线. ...
- 2021record
2021-10-14 P2577 [ZJOI2004]午餐 2021-10-13 CF815C Karen and Supermarket(小小紫题,可笑可笑) P6748 『MdOI R3』Fall ...
- reactjs入门到实战(十)----one-first_app
index <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <!-- ...
- Codeforces Hello2020 A-E简要题解
contest链接:https://codeforces.com/contest/1284 A. New Year and Naming 思路:签到,字符串存一下,取余拼接. #include< ...
- 【cf比赛记录】Codeforces Round #606 (Div. 2, based on Technocup 2020 Elimination Round 4)
比赛传送门 只能说当晚状态不佳吧,有点头疼感冒的症状.也跟脑子没转过来有关系,A题最后一步爆搜没能立即想出来,B题搜索没有用好STL,C题也因为前面两题弄崩了心态,最后,果然掉分了. A:简单数学 B ...
- CF Grakn Forces 2020 1408E Avoid Rainbow Cycles(最小生成树)
1408E Avoid Rainbow Cycles 概述 非常有趣的题目(指解法,不难,但很难想) 非常崇拜300iq,今天想做一套div1时看见了他出的这套题Grakn Forces 2020,就 ...
- ASP.NET Core搭建多层网站架构【9.2-使用Castle.Core实现动态代理拦截器】
2020/01/31, ASP.NET Core 3.1, VS2019, Autofac.Extras.DynamicProxy 4.5.0, Castle.Core.AsyncIntercepto ...
- 开始是为了结束,结束是新的开始——NOI 2020 游记
Day 0 报道日 晚上的时候我们的教练给我们做考前动员.给我们讲:NOI的五个小时需要认真的规划,不能被T1打乱节奏.他让我们思考明天的策略,把可能出问题的地方都想清楚. 结果后来,宿管给我测体温, ...
- Castle Core 4.0.0 alpha001发布
时隔一年多以后Castle 项目又开始活跃,最近刚发布了Castle Core 4.0.0 的alpha版本, https://github.com/castleproject/Core/releas ...
随机推荐
- 安装Linux Deploy和Termux之后,再安装ftp服务软件都是多余的!
之前以为Debian 9 running via Linux Deploy或者Termux在安卓系统部署之后,一定要安装vsftpd或者pure-ftpd这些专门的ftp服务器软件,才能提供ftp服务 ...
- Thread线程控制之sleep、join、setDaemon方法的用处
Thread线程控制之sleep.join.setDaemon方法的用处 1. sleep方法 public static void sleep(long millis) throws Interru ...
- Java安全之Weblogic 2016-3510 分析
Java安全之Weblogic 2016-3510 分析 首发安全客:Java安全之Weblogic 2016-3510 分析 0x00 前言 续前面两篇文章的T3漏洞分析文章,继续来分析CVE-20 ...
- App控件定位
本文将分享Android相关基础知识和Android APP控件定位工具的使用方法. Android基础知识 Android布局 Android是通过容器的布局属性来管理子控件的位置关系(iOS去掉了 ...
- 【SpringMVC】SpringMVC 异常处理
SpringMVC 异常处理 文章源码 异常处理思路 系统中异常包括两类:预期异常和运行时异常,前者通过捕获异常从而获取异常信息,后者主要通过规范代码开发.测试通过手段减少运行时异常的发生. Cont ...
- LeetCode374 猜数字大小
我们正在玩一个猜数字游戏. 游戏规则如下:我从 1 到 n 选择一个数字. 你需要猜我选择了哪个数字.每次你猜错了,我会告诉你这个数字是大了还是小了.你调用一个预先定义好的接口 guess(int n ...
- 【MySQL】CentOS7中使用systemctl工具管理启动和停止MySQL
centos7以前版本,可以使用这个/etc/init.d/mysqld start 来启动mysql 但是centos7之后,通过systemctl start mysqld.service 这个要 ...
- 鸿蒙的fetch请求加载聚合数据的前期准备工作-手动配置网络权限
目录: 1.双击打开"config.json"文件 2.找到配置网络访问权限位置1 3.配置内容1 4.默认访问内容是空的 5.添加配置内容2 6.复制需要配置的网络二级URL 7 ...
- linux在终端中按下键盘立马反应
想在终端中做个小应用,按下上下左右键能立刻作出反应. 测试程序见下: 1 #include <stdio.h> 2 #include <unistd.h> 3 #include ...
- 两个报文是如何进行 TCP 分组传输
16 | 如何理解TCP的"流"? https://time.geekbang.org/column/article/132443 TCP 是一种流式协议在前面的章节中,我们讲的都 ...