
POJ - 1328 Radar Installation 贪心
发布日期:2021-05-09 01:46:28
浏览次数:13
分类:博客文章
本文共 2317 字,大约阅读时间需要 7 分钟。
Radar Installation
Time Limit: 1000MS | Memory Limit: 10000K | |
Total Submissions: 96177 | Accepted: 21378 |
Description
Assume the coasting is an infinite straight line. Land is in one side of coasting, sea in the other. Each small island is a point locating in the sea side. And any radar installation, locating on the coasting, can only cover d distance, so an island in the sea can be covered by a radius installation, if the distance between them is at most d. We use Cartesian coordinate system, defining the coasting is the x-axis. The sea side is above x-axis, and the land side below. Given the position of each island in the sea, and given the distance of the coverage of the radar installation, your task is to write a program to find the minimal number of radar installations to cover all the islands. Note that the position of an island is represented by its x-y coordinates. Figure A Sample Input of Radar Installations
Input
The input consists of several test cases. The first line of each case contains two integers n (1<=n<=1000) and d, where n is the number of islands in the sea and d is the distance of coverage of the radar installation. This is followed by n lines each containing two integers representing the coordinate of the position of each island. Then a blank line follows to separate the cases. The input is terminated by a line containing pair of zeros
Output
For each test case output one line consisting of the test case number followed by the minimal number of radar installations needed. "-1" installation means no solution for that case.
Sample Input
3 21 2-3 12 11 20 20 0
Sample Output
Case 1: 2Case 2: 1
Source
可将点的坐标转为在x轴上对应的位置,然后根据右端对应的值进行排序判断。
#include#include #include using namespace std;struct pos{ double left,right;};bool flag;bool compare(pos a, pos b){ return a.right < b.right;}int main(){ int n; double d; int m = 1; pos a[1005]; while (~scanf("%d %lf", &n, &d)) { if (!n || !d) { break; } int sum = 1; flag = true; double x, y; for (int i = 0; i d) { flag = false; continue; } a[i].left = x - sqrt(d*d - y*y); a[i].right = x + sqrt(d*d - y*y); } if (!flag) { printf("Case %d: -1\n",m); m++; continue; } sort(a, a + n,compare); double temp = a[0].right; for (int i = 1; i < n; i++) { if (temp
发表评论
最新留言
第一次来,支持一个
[***.219.124.196]2025年04月07日 21时06分12秒
关于作者

喝酒易醉,品茶养心,人生如梦,品茶悟道,何以解忧?唯有杜康!
-- 愿君每日到此一游!
推荐文章
从头实现一个WPF条形图
2019-03-05
使用QT实现一个简单的登陆对话框(纯代码实现C++)
2019-03-05
QT :warning LNK4042: 对象被多次指定;已忽略多余的指定
2019-03-05
GLFW 源码 下载-编译-使用/GLAD配置
2019-03-05
针对单个网站的渗透思路
2019-03-05
Typescript 学习笔记六:接口
2019-03-05
02、MySQL—数据库基本操作
2019-03-05
OpenJDK1.8.0 源码解析————HashMap的实现(一)
2019-03-05
MySQL-时区导致的时间前后端不一致
2019-03-05
2021-04-05阅读小笔记:局部性原理
2019-03-05
go语言简单介绍,增强了解
2019-03-05
架构师入门:搭建基本的Eureka架构(从项目里抽取)
2019-03-05
MongoDB 快速扫盲贴
2019-03-05
one + two = 3
2019-03-05
sctf_2019_easy_heap
2019-03-06
PyQt5之音乐播放器
2019-03-06
Redis进阶实践之十八 使用管道模式提高Redis查询的速度
2019-03-06
SQL注入
2019-03-06
MPI Maelstrom POJ - 1502 ⭐⭐ 【Dijkstra裸题】
2019-03-06
Problem 330A - Cakeminator (思维)
2019-03-06