ACM 雷达设置问题

 

Problem Description

假设海岸线是一条无线长的直线,海岸线的一边是海,一边是陆地,大海中的每个小岛屿可以看成是一个点 。 为了简化题目 , 我们把它看成是一个坐标轴 , X 轴是海岸线 , Y> 0的区域是海, Y<0 的区域是陆地,每个小岛屿就是 Y>0 区域上的一个点。
工作人员准备在海岸线上放置一些雷达,每个雷达有一个固定的作用范围,是一个半径为 d 的圆。如果某个岛屿与雷达相距的距离不大于d ,则该岛屿可以被该雷达覆盖。
给出雷达的作用半径d, 以及每个岛屿的位置, 计算至少需要多少个雷达才能将所有岛屿覆盖。

Input

本题包含多组测试数据 , 请处理至文件结束(EOF),每组测试数据第一行含2个整数 N(1<= N <= 1000) 与 d ,分别表示岛屿的个数及雷达的作用范围d。接下来 N 行,每行两个整数 x 、y 表示某个岛的位置。

Output

每组测试数据输出一个整数,表示至少需要的雷达个数。如果无论怎么放置雷达,都无法覆盖所有岛屿,请输出 “ -1 ”(不包含双引号)。

Sample Input

3 2
1 2
-3 1
2 1
1 2
0 2

Sample Output

2
1

Author

tianzuwei

思考:此题此题在于求最小的雷达数。我开始所想,得到所有岛屿所在的位置,找出最大x坐标和最小y坐标,然后遍历这些点,找能同时覆盖很多岛屿的地方。仔细想想好像行不通。就放弃了。看了某一个大佬的博客再发现自己的问题࿰

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值