poj1328
题意:
地图的x轴的上方为海,下方为陆地,海中有n个小岛。
有一种雷达,能探测到的范围为以d为半径的圆。
问海岸线上至少造多少雷达可以把所有的小岛都包含在内。
注意雷达是建在海岸线上的,也就是x轴上的。
思路:
最后肯定每个岛屿都在一个雷达的范围内,通过半径d,岛屿的y坐标计算出雷达的范围,然后按照雷达左范围从小到大排序,
最后如果这个岛屿在雷达的最大范围maxx内,就更新最大范围,否则需要另一个雷达,ans++。
#include <string.h>
#include <stdio.h>
#include <math.h>
#include <queue>
#include <stack>
#include <algorithm>
#define ll long long
using namespace std;
const int maxn=11000;
struct node
{
double x,y;
} pp[maxn];
bool cmp(node a,node b)
{
return a.x<b.x;
}
int main()
{
int i,j,n,d,a,b;
int f=1;
while(~scanf("%d%d",&n,&d)&&n&&d)
{
int ans=1;
for (i=0; i<n; i++)
{
scanf("%d%d",&a,&b);
if (b>d)
ans=-1;
double len=sqrt(d*d-b*b);
pp[i].x=a-len;
pp[i].y=a+len;
}
if (ans!=-1)
{
sort(pp,pp+n,cmp);
double maxx=pp[0].y;
for (i=1; i<n; i++)
{
if (pp[i].x>maxx)
{
ans++;
maxx=pp[i].y;
}
else if(pp[i].y<maxx)
maxx=pp[i].y;
}
}
printf("Case %d: %d\n",f++,ans);
}
return 0;
}
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】博客园社区专享云产品让利特惠,阿里云新客6.5折上折
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· Java 中堆内存和栈内存上的数据分布和特点
· 开发中对象命名的一点思考
· .NET Core内存结构体系(Windows环境)底层原理浅谈
· C# 深度学习:对抗生成网络(GAN)训练头像生成模型
· .NET 适配 HarmonyOS 进展
· 手把手教你更优雅的享受 DeepSeek
· 腾讯元宝接入 DeepSeek R1 模型,支持深度思考 + 联网搜索,好用不卡机!
· AI工具推荐:领先的开源 AI 代码助手——Continue
· 探秘Transformer系列之(2)---总体架构
· V-Control:一个基于 .NET MAUI 的开箱即用的UI组件库