您的位置:首页 > 其它

BZOJ2429 :[HAOI2006]聪明的猴子

2017-09-21 19:46 239 查看
Description

在一个热带雨林中生存着一群猴子,它们以树上的果子为生。昨天下了一场大雨,现在雨过天晴,但整个雨林的地

表还是被大水淹没着,部分植物的树冠露在水面上。猴子不会游泳,但跳跃能力比较强,它们仍然可以在露出水面

的不同树冠上来回穿梭,以找到喜欢吃的果实。现在,在这个地区露出水面的有N棵树,假设每棵树本身的直径都

很小,可以忽略不计。我们在这块区域上建立直角坐标系,则每一棵树的位置由其所对应的坐标表示(任意两棵树

的坐标都不相同)。在这个地区住着的猴子有M个,下雨时,它们都躲到了茂密高大的树冠中,没有被大水冲走。由

于各个猴子的年龄不同、身体素质不同,它们跳跃的能力不同。有的猴子跳跃的距离比较远(当然也可以跳到较近

的树上),而有些猴子跳跃的距离就比较近。这些猴子非常聪明,它们通过目测就可以准确地判断出自己能否跳到

对面的树上。【问题】 现已知猴子的数量及每一个猴子的最大跳跃距离,还知道露出水面的每一棵树的坐标,你

的任务是统计有多少个猴子可以在这个地区露出水面的所有树冠上觅食。

Input

第1行为一个整数,表示猴子的个数M(2<=M<=500);

第2行为M个整数,依次表示猴子的最大跳跃距离(每个整数值在1–1000之间);

第3行为一个整数表示树的总棵数N(2<=N<=1000);

第4行至第N+3行为N棵树的坐标(横纵坐标均为整数,范围为:-1000–1000)。

(同一行的整数间用空格分开)

Output

包括一个整数,表示可以在这个地区的所有树冠上觅食的猴子数

Sample Input

4

1 2 3 4

6

0 0

1 0

1 2

-1 -1

-2 0

2 2

Sample Output

3

HINT

2<=N <= 1000,1<=M=500

题目传送门

最近刷最小生成树有一点点上瘾

求最短路的最长边,最小生成树秒切数据….

然后…

建边数组开小了WA差不多n次(n>=5)

代码如下:

#include<cmath>
#include<cstdio>
#include<cstring>
#include<cstdlib>
#include<algorithm>
using namespace std;
int fa[1100];
int f[1100];
struct node
{
int x,y;
double d;
}a[2100000];int len;
int x[1100],y[1100];
int cmp(const void*x1,const void*x2)
{
node n1=*(node*)x1;
node n2=*(node*)x2;
if(n1.d>n2.d)return 1;
else if(n2.d>n1.d)return -1;
return 0;
}
int findfa(int x)
{
if(fa[x]!=x)return findfa(fa[x]);
return x;
}
double dis(int i,int j)
{
return sqrt((x[i]-x[j])*(x[i]-x[j])+(y[i]-y[j])*(y[i]-y[j]));
}
int m,n;
int main()
{
scanf("%d",&m);len=0;
for(int i=1;i<=m;i++)scanf("%d",&f[i]);
scanf("%d",&n);
for(int i=1;i<=n;i++)scanf("%d%d",&x[i],&y[i]);
for(int i=1;i<=n;i++)
for(int j=1;j<=n;j++)
if(i!=j)
{
len++;
a[len].x=i;a[len].y=j;a[len].d=dis(i,j);
}
for(int i=1;i<=n;i++)fa[i]=i;
qsort(a+1,len,sizeof(node),cmp);
double t=0;int tot=0;
for(int i=1;i<=len;i++)
{
int xx=a[i].x,yy=a[i].y;
int fx=findfa(xx),fy=findfa(yy);
if(fx!=fy)
{
tot++;
fa[fy]=fx;
}
if(tot==n-1){t=a[i].d;break;}
}
int ans=0;
for(int i=1;i<=m;i++)if(f[i]>=t)ans++;
printf("%d\n",ans);
return 0;
}


by_lmy
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: