(有任何问题欢迎留言或私聊 && 欢迎交流讨论哦

题意:传送门

题目描述 
Z市是一座港口城市,来来往往的船只依靠灯塔指引方向。 
在海平面上,存在n个灯塔。每个灯塔可以照亮以它的中心点为中心的90°范围。特別地, 由于特殊限制,每个灯塔照亮范围的角的两条边必须要么与坐标轴平行要么与坐标轴成45°。 由于经费限制,Z市的灯塔只能被点亮一座。你需要求出在这种情况下,是否存在一座灯塔能够照亮Z市的所有灯塔。 
输入描述: 
第一行一个整数T,表示数据组数。 
对于每组数据,第一行一个整数n,表示灯塔的数量。 
接下来n行,每行两个整数xi,yi,表示第i座灯塔的坐标点。 
输出描述: 
如果存在一座灯塔能够照亮Z市的所有灯塔则输出Yes,否则输出No(区分大小写)。

思路:

 首先选取最上面最下面最左边最右边的四个点。 
 然后枚举这四个点,算出其他所有点到这一个点的角度,然后排序。 
 排完序之后看这点角度符不符合题目所说的要求。要么全在一个象限内,要么在y=xy=x和y=−xy=−x俩直线之间。

丫的,之前百度了一份凸包模版,然后一直不对,后来删掉凸包部分就过了,恶心 
 然后在日天学长要了一份凸包模版,这tm才是正确的凸包嘛,用了日天的凸包也过了。凸包模版请看这里:传送门

AC代码:

#include <bits/stdc++.h>
using namespace std;
typedef long long LL;
const int MX = 1e6 + ;
const double pi = acos(-1.0);
struct lp {
LL x, y;
} cw[MX],R[MX],op[],ok;
bool cmp1(lp &a, lp &b){
return a.x<b.x;
}
bool cmp2(lp &a, lp &b){
return a.y<b.y;
}
double ans[MX];
int main() {
#ifndef ONLINE_JUDGE
freopen("E://ADpan//in.in", "r", stdin);
//freopen("E://ADpan//out.out", "w", stdout);
#endif
int T, n;
scanf("%d",&T);
while(T--) {
scanf("%d",&n);
for(int i=;i<n;++i){
scanf("%lld%lld",&cw[i].x,&cw[i].y);
}
int flag = ;
sort(cw,cw+n,cmp2);
op[]=cw[],op[]=cw[n-];
sort(cw,cw+n,cmp1);
op[]=cw[],op[]=cw[n-];
double haha = pi/;
for(int t=;t<=;++t){
int tn = ;
ok=op[t];
int res=;
for(int i=;i<n;++i){
if(cw[i].x==ok.x&&cw[i].y==ok.y)continue;
ans[tn++]=atan2(cw[i].y-ok.y*1.0,1.0*cw[i].x-ok.x);
if(ans[tn-]>-pi*/&&ans[tn-]<pi*/)res=;
}
sort(ans,ans+tn);
double mmax=ans[tn-],mmin=ans[];
if(mmax<=-haha)flag=;
if(mmin>=-*pi/&&mmax<=-pi/)flag=;
if(mmin>=-haha&&mmax<=)flag=;
if(mmin>=-pi/&&mmax<=pi/)flag=;
if(mmin>=&&mmax<=haha)flag=;
if(mmin>=pi/&&mmax<=pi*/)flag=;
if(mmin>=haha&&mmax<=pi)flag=;
if(res)flag=;
}
if(flag)printf("Yes\n");
else printf("No\n");
}
return ;
}

Wannafly挑战赛21-A-灯塔-内含正确的凸包模版的更多相关文章

  1. Wannafly挑战赛21:C - 大水题

    链接:Wannafly挑战赛21:C - 大水题 题意: 现在给你N个正整数ai,每个数给出一“好数程度” gi(数值相同但位置不同的数之间可能有不同的好数程度).对于在 i 位置的数,如果有一在j位 ...

  2. 牛客网 Wannafly挑战赛21 灯塔

    Z市是一座港口城市,来来往往的船只依靠灯塔指引方向.在海平面上,存在n个灯塔.每个灯塔可以照亮以它的中心点为中心的90°范围.特別地, 由于特殊限制,每个灯塔照亮范围的角的两条边必须要么与坐标轴平行要 ...

  3. Wannafly挑战赛21 E 未来城市规划

    传送门 题目中给的信息很难直接维护,但是可以考虑一条边对答案的贡献 在以\(x\)为根的子树里,如果一条边\(i\)的权值为\(w_i\),这条边深度更深的端点为\(to_i\),那么这条边对这个子树 ...

  4. Wannafly挑战赛21 C 大水题

    https://www.nowcoder.com/acm/contest/159/C dp #include <cstdio> #include <cstdlib> #incl ...

  5. Wannafly挑战赛21 机器人

    从前在月球上有一个机器人.月球可以看作一个 n*m 的网格图,每个格子有三种可能:空地,障碍,机器人(有且仅有一个),现在地面指挥中心想让机器人在月球上行走,每次可以发送一个指令,为 U-往上走.D- ...

  6. 【Wannafly挑战赛4】F 线路规划 倍增+Kruskal+归并

    [Wannafly挑战赛4]F 线路规划 题目描述 Q国的监察院是一个神秘的组织.这个组织掌握了整个帝国的地下力量,监察着Q国的每一个人.监察院一共有N个成员,每一个成员都有且仅有1个直接上司,而他只 ...

  7. Wannafly挑战赛13 zzf的好矩阵 题解 答案解释

    Wannafly挑战赛13 zzf的好矩阵 题解 文章目录 Wannafly挑战赛13 zzf的好矩阵 题解 分析 结论1 结论2 结论3 C数组对应带子说明 空白长度论述 后续黑色长度论述 能&qu ...

  8. Wannafly挑战赛25游记

    Wannafly挑战赛25游记 A - 因子 题目大意: 令\(x=n!(n\le10^{12})\),给定一大于\(1\)的正整数\(p(p\le10000)\)求一个\(k\)使得\(p^k|x\ ...

  9. Wannafly挑战赛27

    Wannafly挑战赛27 我打的第一场$Wannafly$是第25场,$T2$竟然出了一个几何题?而且还把我好不容易升上绿的$Rating$又降回了蓝名...之后再不敢打$Wannafly$了. 由 ...

随机推荐

  1. 使用并行ssh提高工作效率

    我们经常需要ssh到多个主机上执行相同的命令,为了提高效率,我们通常会自己写个脚本,循环遍历执行我们的命令,比如: for host in `cat hosts.txt`;do ssh usernam ...

  2. HTTP六大请求

    标准Http协议支持六种请求方法,即: 1.GET 2.POST 3.PUT 4.Delete 5.HEAD 6.Options 但其实我们大部分情况下只用到了GET和POST.如果想设计一个符合RE ...

  3. git分布式版本控制系统权威指南学习笔记(五):git checkout

    文章目录 分离头指针 通过cat可以查看当前的分支 通过branch查看当前分支 checkout commitId(真正的

  4. Mysql DBA

    1 mysqldump: Error 2020: Got packet bigger than 'max_allowed_packet' bytes when dumping table `tb_co ...

  5. 使用U盘或在本地电脑作为git远程仓库进行托管

    情景描述: 当有两台电脑需要共同维护一段代码,其中一台电脑不希望(或者不能)通过网络的方式进行访问git仓库(即不使用github),那么可以使用U盘作为介质将其作为远程仓库,或者使用局域网中一台电脑 ...

  6. centos安装vbox addition

    在centos下安装vbox addition需要下载当前内核的头文件 yum install kernel-devel 但是下载了头文件后,仍然失败,原来是下载的头文件与当前的内核版本不对应, 于是 ...

  7. 分析由Python编写的大型项目(Volatility和Cuckoo)

    之前使用python都是用来做一些简单的脚本,本质上和bat批处理文件没有区别. 但是Python是可以用来编写大型的项目的,比如: Volatility:https://code.google.co ...

  8. ssh 登陆免 known_hosts 提示

    修改配置文件 “~/.ssh/config”,加上这两行,重启服务器: StrictHostKeyChecking no UserKnownHostsFile /dev/null

  9. Linux SSH证书登陆

    创建证书 ssh-keygen -t rsa -b 4096 -C "your_email@example.com" 证书导入以后,执行 eval "$(ssh-agen ...

  10. BOM 3.1 location对象 | history对象 | navigator对象 | 定时器 | 三大系列

    JavaScript分三个部分: 1. ECMAScript标准---基本语法 2. DOM--->Document Object Model 文档对象模型,操作页面元素的 3. BOM---& ...