HDU 4946 Area of Mushroom 凸包 第八次多校
题意:一大神有N个学生,各个都是小神,大神有个二次元空间,每一个小神都有一个初始坐标,如今大神把这些空间分给徒弟们,规则是假设这个地方有一个人比谁都先到这,那么这个地方就是他的,问谁的地盘面积是无穷大的.
思路:由于空间是无限大的,所以仅仅要速度最大就有可能有无限的地盘,重合的点不能严格的比对方快,也不符合规定,然后求速度最大的点围城的凸包,凡是在凸包上的点且不重合的,地盘都是无穷大.
比赛的时候,不会凸包的,现找的模板,不了解性能,不知道计算凸包不能传重合的点进去结果WA出翔
#include <cstdio>
#include <cstring>
#include <iostream>
#include <cmath>
#include <queue>
#include <vector>
#include <algorithm> #define INF 1e9
#define maxn 1000
#define EPS 1e-6 #define N 1000
using namespace std;
struct point
{
int x,y; //横纵坐标 : x,y
double len,theta; //与參考点的距离 len 与參考点构成的向量与 (1,0)向量构成的夹角的余弦值 theta
}g[N]; //定义了一个全局变量,记录凸包中的点
/*--------按余弦值,从大到小高速排序--------*/
void qsort(int st,int en)
{
int i=st,j=en;
g[0]=g[i];
while(i<j)
{
while(i<j && g[0].theta>=g[j].theta) j--;
if(i<j) { g[i]=g[j]; i++; }
while(i<j && g[0].theta<=g[i].theta) i++;
if(i<j) { g[j]=g[i]; j--; }
}
g[i]=g[0];
if(st<i-1) qsort(st,i-1);
if(i+1<en) qsort(i+1,en);
} /*-----------Graham 扫描法-------------*/
void graham(int *n)
{
/*第一步,寻找y坐标最小,然后x坐标最小的点*/
int p=1;
for(int i=2;i<=*n;i++)
if((g[i].y<g[p].y)||(g[i].y==g[p].y && g[i].x<g[p].x)) p=i;
g[0]=g[p]; g[p]=g[1]; g[1]=g[0];
/*找到该点,并把它存放在 g 中的第一个元素的位子上*/ /*第二步,计算全部的点距离參考点的距离(len) 还有夹角的余弦值 (theta)*/
for(int i=2;i<=*n;i++)
{
g[i].len=sqrt((g[i].x-g[1].x)*(g[i].x-g[1].x)+(g[i].y-g[1].y)*(g[i].y-g[1].y));
g[i].theta=100*(g[i].x-g[1].x)/g[i].len;
}
qsort(2,*n);//先依据夹角的余弦值从大到小排序 /*第三步,将全部theta值相等的点,仅仅保存len值最大的,存放在数组map中*/
point map[N];
int tot=0; p=1;
while(p<=*n)
{
int k=p;
while(fabs(g[p].theta-g[p+1].theta)<=EPS)
{
if(g[p+1].len>g[k].len) k=p+1;
p++;
}
map[++tot]=g[k];
p++;
} /*第四步,对map中的元素扫描一遍,确定凸包的元素,放在数组g中*/
*n=tot; tot=3; //先做了一个小小的处理,使得自己更好理解
memset(g,0,sizeof(g));
g[1]=map[1]; g[2]=map[2]; g[3]=map[3]; //先将前三个点入栈 g
for(int i=4;i<=*n;i++) //依次用map中的每一个点对g中的点进行一次推断,看是否是属于凸包
{
double chaji=(g[tot].x-g[tot-1].x)*(map[i].y-g[tot].y)-(map[i].x-g[tot].x)*(g[tot].y-g[tot-1].y);
for(;chaji<=0 && tot>=1;) //假设旋转的方向不同,g[tot]这个点就不是,删除,并继续推断 g 中下一个点是不是
{
tot--;
chaji=(g[tot].x-g[tot-1].x)*(map[i].y-g[tot].y)-(map[i].x-g[tot].x)*(g[tot].y-g[tot-1].y);
}
g[++tot]=map[i]; //将map[i]这个点入栈,至于是否是属于凸包中的点,等待以后的点来推断
}
*n=tot;//凸包处理完,总共同拥有tot个凸包上的点
} /*---------------------------------------------------------------------------------------------*/ struct Node{
int x,y,v,rank,bl;
}tmp;
int maxe;
vector<Node> stu;
int cas=0;
bool cmp(Node a,Node b)
{
return a.rank<b.rank;
}
void init(int n)
{
stu.clear();
maxe=0;
for(int i=0;i<n;i++)
{
scanf("%d %d %d",&tmp.x,&tmp.y,&tmp.v);
tmp.rank=i;
tmp.bl=0;
stu.push_back(tmp);
maxe=max(tmp.v,maxe);
}
}
bool check(int a,int b,int tt)
{
int c;
if(b==tt)
{
c=1;
}else
{
c=b+1;
}
double chaji=(g[c].x-g[b].x)*(stu[a].y-g[c].y)-(stu[a].x-g[c].x)*(g[c].y-g[b].y);
if(chaji<=EPS) return 1;
else return 0;
} int main()
{
//freopen("data.in","r",stdin);
int n;
while (~scanf("%d",&n))
{
if(n==0) break;
printf("Case #%d: ",++cas);
init(n); if(maxe==0)
{
for(int i=0;i<n;i++)
{
printf("0");
}
}
else
{
for(int i=0;i<n;i++)
{
if(stu[i].v==maxe)
{
stu[i].bl=1;
}
}
for(int i=0;i<n-1;i++)
{
if(stu[i].bl==1)//错误写法: if(stu[i].v=maxe)
{
for(int j=i+1;j<n;j++)
{
if(stu[i].x==stu[j].x&&stu[i].y==stu[j].y&&stu[i].v==stu[j].v&&i!=j)
{
stu[j].bl=0;
stu[i].bl=-1;
}
}
}
}
int tt=0;
for(int i=0;i<n;i++)
{
if(stu[i].v==maxe&&stu[i].bl!=0)
{ g[++tt].x=stu[i].x;
g[tt].y=stu[i].y;
}
}
//printf("%d\n",tt);
if(tt>=3)
{
graham(&tt);
for(int i=0;i<n;i++){
if(stu[i].bl==1){
stu[i].bl=0;
for(int j=1;j<=tt;j++)
{
if((stu[i].x==g[j].x&&stu[i].y==g[j].y)||check(i,j,tt))
{
stu[i].bl=1;
break;
}
}
}
}
}
sort(stu.begin(),stu.end(),cmp);
for(int i=0;i<n;i++)
{
if(stu[i].bl==-1)
stu[i].bl=0;
printf("%d",stu[i].bl);
}
} puts("");
}
return 0;
}
HDU 4946 Area of Mushroom 凸包 第八次多校的更多相关文章
- HDU 4946 Area of Mushroom 凸包
链接:pid=4946">http://acm.hdu.edu.cn/showproblem.php?pid=4946 题意:有n个人.在位置(xi,yi),速度是vi,假设对于某个点 ...
- hdu 4946 Area of Mushroom(凸包)
链接:http://acm.hdu.edu.cn/showproblem.php?pid=4946 Area of Mushroom Time Limit: 2000/1000 MS (Java/Ot ...
- HDU 4946 Area of Mushroom(构造凸包)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4946 题目大意:在一个平面上有n个点p1,p2,p3,p4....pn,每个点可以以v的速度在平面上移 ...
- HDU 4946 Area of Mushroom (几何凸包)
题目链接 题意:给定n个人,每个人有一个速度v方向任意.如果平面中存在一个点只有某个人到达的时间最短(即没有人比这个人到的时间更短或相同),那么我们定义这个店归这个人管辖,现在问这些人中哪些人的管辖范 ...
- HDU 4946 Area of Mushroom 共线凸包
题意是在二维平面上 给定n个人 每一个人的坐标和移动速度v 若对于某个点,仅仅有 x 能最先到达(即没有人能比x先到这个点或者同一时候到这个点) 则这个点称作被x占有 若有人能占有无穷大的面积 则输出 ...
- hdu 4946 Area of Mushroom (凸包,去重点,水平排序,留共线点)
题意: 在二维平面上,给定n个人 每个人的坐标和移动速度v 若对于某个点,只有 x 能最先到达(即没有人能比x先到这个点或者同时到这个点) 则这个点称作被x占有,若有人能占有无穷大的面积 则输出1 , ...
- HDU 4946 Area of Mushroom(2014 Multi-University Training Contest 8)
思路: 只有速度最大才有可能为1,速度不是最大肯定为0,那么就是 只需要操作那些速度最大的点,这些点求一个凸包,判断一下是不是在凸包边上即可. 有几个需要注意的地方: 1.最大速度如果为0 那么肯 ...
- HDU 4946 凸包
给你n个点,具有速度,一个位置如果有其他点能够先到,则不能继续访问,求出里面这些点哪些点是能够无限移动的. 首先我们考虑到,一个速度小的和一个速度大的,速度小的必定只有固定他周围的一定区域是它先到的, ...
- hdu 4946 2014 Multi-University Training Contest 8
Area of Mushroom Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others) ...
随机推荐
- c# 获取某个对象的[公有属性]的名称,类型,值
/// <summary> /// 获取某个对象的[公有属性]的名称,类型,值 /// </summary> /// <typeparam name="T&qu ...
- Dubbo与Zookeeper、SpringMVC整合和使用(负载均衡、容错)(转)
互联网的发展,网站应用的规模不断扩大,常规的垂直应用架构已无法应对,分布式服务架构以及流动计算架构势在必行,Dubbo是一个分布式服务框架,在这种情况下诞生的.现在核心业务抽取出来,作为独立的服务,使 ...
- 【从翻译mos文章】不再用par file如果是,export or import 包含大写和小写表名称表
不再用par file如果是,export or import 包含大写和小写表名称表 参考原始: How to Export or Import Case Sensitive Tables With ...
- maven/eclipse搭建ssm(spring+spring mvc+mybatis)
maven/eclipse搭建ssm(spring+spring mvc+mybatis) 前言 本文旨在利用maven搭建ssm环境,而关于maven的具体内容,大家可以去阅读<Maven 实 ...
- HDU 4864Task(更多的联合培训学校1)(贪婪)
职务地址:pid=4864">HDU4864 这题又是一上来觉得是最小费用流,可是边太多.果然,敲完交上去后不断TLE.. 小优化了两次也没过. . . sad.. 后来看了题解才发现 ...
- 网络视频播放器插件ckplayer使用-简介
ckplayer插件下载:http://pan.baidu.com/s/12HYH4(假设不见了,下载您自己的地址,下载后添加到站点根文件夹) ******特别提醒:解压后不要忘了把js文件夹也加入到 ...
- Appium之java API
AppiumDriver getAppStrings() 默认系统语言相应的Strings.xml文件内的数据. driver.getAppStrings(String language) 查找某一个 ...
- UVA 257 - Palinwords(弦HASH)
UVA 257 - Palinwords 题目链接 题意:输出一个文本里面的palinword,palinword的定义为.包括两个不同的回文子串,而且要求回文子串不能互相包括 思路:对于每一个单词推 ...
- apache kafka系列之-监控指标
apache kafka中国社区QQ群:162272557 1.监控目标 1.当系统可能或处于亚健康状态时及时提醒,预防故障发生 2.报警提示 a.短信方式 b.邮件 2.监控内容 2.1 机器监控 ...
- MVC5 Entity Framework学习之实现继承
之前你已经学习了怎样处理并发异常,在本节中你将学习怎样实现继承. 在面向对象的编程中,你能够使用继承来重用代码.接下来你将改动Instructor和Student类,让它们派生自Person基类,该基 ...