题目链接:hdu 4946

题意:一大神有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 凸包 第八次多校的更多相关文章

  1. HDU 4946 Area of Mushroom 凸包

    链接:pid=4946">http://acm.hdu.edu.cn/showproblem.php?pid=4946 题意:有n个人.在位置(xi,yi),速度是vi,假设对于某个点 ...

  2. hdu 4946 Area of Mushroom(凸包)

    链接:http://acm.hdu.edu.cn/showproblem.php?pid=4946 Area of Mushroom Time Limit: 2000/1000 MS (Java/Ot ...

  3. HDU 4946 Area of Mushroom(构造凸包)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4946 题目大意:在一个平面上有n个点p1,p2,p3,p4....pn,每个点可以以v的速度在平面上移 ...

  4. HDU 4946 Area of Mushroom (几何凸包)

    题目链接 题意:给定n个人,每个人有一个速度v方向任意.如果平面中存在一个点只有某个人到达的时间最短(即没有人比这个人到的时间更短或相同),那么我们定义这个店归这个人管辖,现在问这些人中哪些人的管辖范 ...

  5. HDU 4946 Area of Mushroom 共线凸包

    题意是在二维平面上 给定n个人 每一个人的坐标和移动速度v 若对于某个点,仅仅有 x 能最先到达(即没有人能比x先到这个点或者同一时候到这个点) 则这个点称作被x占有 若有人能占有无穷大的面积 则输出 ...

  6. hdu 4946 Area of Mushroom (凸包,去重点,水平排序,留共线点)

    题意: 在二维平面上,给定n个人 每个人的坐标和移动速度v 若对于某个点,只有 x 能最先到达(即没有人能比x先到这个点或者同时到这个点) 则这个点称作被x占有,若有人能占有无穷大的面积 则输出1 , ...

  7. HDU 4946 Area of Mushroom(2014 Multi-University Training Contest 8)

    思路: 只有速度最大才有可能为1,速度不是最大肯定为0,那么就是 只需要操作那些速度最大的点,这些点求一个凸包,判断一下是不是在凸包边上即可. 有几个需要注意的地方: 1.最大速度如果为0   那么肯 ...

  8. HDU 4946 凸包

    给你n个点,具有速度,一个位置如果有其他点能够先到,则不能继续访问,求出里面这些点哪些点是能够无限移动的. 首先我们考虑到,一个速度小的和一个速度大的,速度小的必定只有固定他周围的一定区域是它先到的, ...

  9. 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) ...

随机推荐

  1. xhost和XServer相关概念汇总

    1.xhost 控制什么人可以访问当前主机上的增强 X-Windows.语法:xhost [ + | - ] [ Name ] 2.xhost 是用来控制X server访问权限的.通常当你从host ...

  2. Swift新手教程3-字符串String

    原创blog,转载请注明出处 String 在swfit中,String兼容Unicode的方式.用法和C语言类似. 注意   在Cocoa和Cocoa touch中,Swift的String,和Fo ...

  3. 国内三大PTPrivate Tracker站分析

    除这一行外,下面全部内容都是转载.出处不明. 国内三大PT(Private Tracker)站分析 先郑重的声明一下:本文以下的内容所有是复制粘贴的,不代表老夫的观点. 事实上内容我也没细致看. 贴这 ...

  4. ORACLE profile列4 --CREATE PROFILE

    这个博客是ORACLE profile系列第四部分.主要说一下,假设你创建profile而使用profile资源和password控制 CREATE PROFILE Note: Oracle reco ...

  5. javascript动画中的“帧”

    在写游戏的时候,动画移动的速度需要保持一致,为了在各个软硬件环境中速度的一致,需要考虑帧频的不同. 计算时间系数: 时间系数 = 目标FPS / 实际FPS 计算实际FPS actualFPS = 1 ...

  6. spring常规任务(轻便易)

    spring提供了定时任务功能.我们不需要第三者jar包支持.spring够了. 代码: package com.inth.product.web.task; import java.util.Dat ...

  7. IIS7启用静态压缩

    IIS7启用压缩的操作如下图: 默认情况下IIS7是启用GZip压缩的,但是有时候我们会发现谁然启用了压缩但是一些js和css文件仍然没有被压缩,这个时候需要修改一下IIS 的配置文件: 在C:\Wi ...

  8. Following unknown configure options were used:--enable-fpm

    跑cd   php-5.2.13安装时间 ./configure --prefix=/usr/local/php/ --with-config-file-path=/usr/local/php/etc ...

  9. 创建在SQLServer 和 Oracle的 DBLINK

    dblink 当我们要跨本地数据库.訪问另外一个数据库表中的数据时,本地数据库中就必需要创建远程数据库的dblink,通过dblink本地数据库能够像訪问本地数据库一样訪问远程数据库表中的数据. 一 ...

  10. 快讯:埃博拉患者Martin Salia去天堂了

    下面是Martin Salia外科医生的遗像: 11月17日,埃博拉重病患者Martin Salia外科医生死了.请见:Ebola patient Dr. Martin Salia dies in O ...