挑战程序设计竞赛 2.2 poj 1328 Radarinstallation
https://vjudge.net/problem/POJ-1328
假设海岸线是一条无限长的直线。陆地在海岸线的一边,海洋在另一边。每个小岛都是位于海边的一个点。
而位于海岸线上的任何雷达装置都只能覆盖 d 的距离,因此,如果两者之间的距离最多为 d,那么海中的一个小岛就可以被一个半径为 d 的装置覆盖。
我们使用直角坐标系,将海岸线定义为 x 轴。海面在 x 轴上方,陆地在 x 轴下方。
给定每个岛屿在海中的位置,并给定雷达装置的覆盖距离,你的任务是编写一个程序,找出覆盖所有岛屿的最小雷达装置数量。
请注意,岛屿的位置由其 x-y 坐标表示。
输入包括几个测试用例。每个案例的第一行包含两个整数 n(1<=n<=1000)和 d,其中 n 是海中岛屿的数量,d 是雷达装置的覆盖距离。
随后是 n 行,每行包含两个整数,分别代表每个岛屿的位置坐标。然后用一行空行来分隔情况。
输入以一行包含一对 0 的行结束
每个测试用例输出一行,包括测试用例编号,以及所需的最少雷达安装数量。"-1 "表示该案例没有解决方案。
3 2
1 2
-3 1
2 1
1 2
0 2
0 0
Case 1: 2
Case 2: 1
通过岛屿圆的半径将半径问题转化为线段贪心问题
#include <iostream>
#include <algorithm>
#include <cmath>
using namespace std;
//https://vjudge.net/problem/POJ-1328
int n, d;
const int N = 1010;
int t = 1;
struct Node {
double l, r;
}nodes[N];
bool cmp(const struct Node& a, const struct Node& b) {
if (a.l > b.l) return true;
return false;
}
void solve() {
sort(nodes,nodes+n,cmp);
int ans = 0; double currl = -99999999; double currr = -99999999;
for (int i = 0; i < n; i++) {
if (nodes[i].l > currr || nodes[i].r < currl) {
ans++; currl = nodes[i].l; currr = nodes[i].r;
}
else {
currl = max(currl, nodes[i].l);
currr = min(currr, nodes[i].r);
}
}
cout << "Case " << t++ << ": " <<ans << endl;
}
int main()
{
while (cin >> n >> d) {
if (n == 0 && d == 0) break;
int flag = 1;
for (int i = 0; i < n; i++) {
int x, y; cin >> x >> y;
if (y < 0) continue;
if (d < y) flag = 0;
double l = x - (double)sqrt((double)d * d - y * y);
double r = x + (double)sqrt((double)d * d - y * y);
nodes[i].l = l; nodes[i].r = r;
}
if (flag == 0) {
cout << "Case " << t++ << ": " << -1 << endl; continue;
}
solve();
}
return 0;
}
作 者: itdef
欢迎转帖 请保持文本完整并注明出处
技术博客 http://www.cnblogs.com/itdef/
B站算法视频题解
https://space.bilibili.com/18508846
qq 151435887
gitee https://gitee.com/def/
欢迎c c++ 算法爱好者 windows驱动爱好者 服务器程序员沟通交流
如果觉得不错,欢迎点赞,你的鼓励就是我的动力
欢迎转帖 请保持文本完整并注明出处
技术博客 http://www.cnblogs.com/itdef/
B站算法视频题解
https://space.bilibili.com/18508846
qq 151435887
gitee https://gitee.com/def/
欢迎c c++ 算法爱好者 windows驱动爱好者 服务器程序员沟通交流
如果觉得不错,欢迎点赞,你的鼓励就是我的动力


标签:
挑战程序设计竞赛
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列1:轻松3步本地部署deepseek,普通电脑可用
· 按钮权限的设计及实现
· 25岁的心里话
2018-10-03 bittorrent 学习(一) 种子文件分析与bitmap位图