链接:https://ac.nowcoder.com/acm/contest/3570/C

来源:牛客网

题目描述

Hbb is a general and respected by the entire people of the Empire.

The wizard will launch an attack in the near future in an attempt to

destroy the empire. Hbb had knew the way the Wizards will attack this

time: they will summon N bone dragons on the broad flat ground outside

the wall and let the bone dragons spray a flame (the flame can only be

emitted once). If the wall is sprayed by flames, the wall will be

completely destroyed in an instant. To withstand the wizard’s attack,

Hbb feels very anxious, although he already knew where all the bone

dragons would be summoned. Coincidentally, scientists at the

Capital Laboratory have developed a new type of weapon. The striking

range of the weapon is a circle with the weapon as the center and a

radius of D. In other words, if the weapons are properly placed, the

bone dragons within the strike range will be destroyed. Weapons can

only be placed on the wall, but Hbb is too anxious at this time to

know how to place the weapon, so he tells you the position of the bone

dragon . Since the cost of the weapon is very expensive, Hbb gives you

a requirement: tell him what the minimum number of weapons to use in

order to destroy all bone dragons. If there is no way to destroy all

bone dragons, output -1.

输入描述: The input consists of several test cases. The first line of each

case contains two integers and , where is the number of bone dragon

in the ground and is the distance of coverage of the weapon. Then is

followed by lines each containing two integers and , representing

the coordinate of the position of each bone dragon. Then a blank line

follows to separate the cases. The input is terminated by a line

containing pair of zeros 输出描述: For each test case output one line

consisting of the test case number followed by the minimal number of

weapon needed. “-1” installation means no solution for that case. 示例1

输入

3 2
1 2
-3 1
2 1 1 2
0 2 0 0
输出
Case 1: 2
Case 2: 1

备注:



Case1 is explained in the figure, the wall is regarded as the X axis, and the weapon can only be placed on the X axis. The red circle is the weapon strike range.


思路如下

题意:

给出n头骨龙的坐标(只会在第一、第二象限),在X轴上放置武器,每个武器都有相同的固定打击范围D,问最少需要多少武器可以将所有骨龙覆盖,如果不能覆盖所有骨龙则输出-1.

思路:

贪心:要想武器打击范围能够覆盖所有的龙骨,若可以覆盖,则以每头龙为圆心,以D为半径,则必定与x轴有两个焦点,在两个交点所在的区间内就是我们可以放置武器的地方,因此计算出所有骨龙与X轴相交的两个点,按照左端点排序(或者右端点),遍历所有骨龙,判断左右边的武器是否能够覆盖当前遍历到的骨龙的,如果不能覆盖,则添置一个新武器于当前骨龙 与X轴交点的最右端。


题解如下

#include<iostream>
#include<cmath>
#include<algorithm>
#define l first
#define r second
#define Pff pair<double,double> //这里的 pair 用的非常恰到好处,pair的两个值恰好存储区间的两个端点
using namespace std; const int Len = 1005;
Pff p[Len];
int n; double d; inline void cal(int &x,int &y,int &i) //计算某个骨龙所对应的武器放置的区间
{
p[i].l = (double)x - sqrt(d * d - y * y);
p[i].r = (double)x + sqrt(d * d - y * y);
} inline void work()
{
sort(p + 1, p + 1 + n); //对各个武器区间进行排序
int ans = 1;
double pos_r = p[1].r;
for(int i = 2; i <= n; ++i)
{
if(p[i].l > pos_r)
{
++ ans;
pos_r = p[i].r;
}
else if(p[i].r < pos_r) //⚠️这里的一步操作一定要理解
{
pos_r = p[i].r;
}
}
printf("%d\n",ans);
} int main()
{
int case_ = 1;
while(~scanf("%d %lf", &n, &d) && n + d)
{ printf("Case %d: ",case_ ++);
int flag = 0,x,y;
for(int i = 1;i <= n;++ i)
{
scanf("%d %d",&x,&y);
if(y > d || flag)
{
flag = 1; //在输入的时候不能够break ,否则就输不进去了
continue;
}
cal(x,y,i);
}
if(flag == 0)
work();
else
printf("-1\n");
}
return 0;
}

C、Guard the empire(贪心)的更多相关文章

  1. bzoj2811[Apio2012]Guard 贪心

    2811: [Apio2012]Guard Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 905  Solved: 387[Submit][Statu ...

  2. bzoj 2811: [Apio2012]Guard【线段树+贪心】

    关于没有忍者的区间用线段树判就好啦 然后把剩下的区间改一改:l/r数组表示最左/最右没被删的点,然后删掉修改后的左边大于右边的:l升r降排个序,把包含完整区间的区间删掉: 然后设f/g数组表示i前/后 ...

  3. 【二分答案+贪心】UVa 1335 - Beijing Guards

    Beijing was once surrounded by four rings of city walls: the Forbidden City Wall, the Imperial City ...

  4. 贪心(qwq)习题题解

    贪心(qwq)习题题解 SCOI 题解 [ SCOI2016 美味 ] 假设已经确定了前i位,那么答案ans一定属于一个区间. 从高位往低位贪心,每次区间查找是否存在使此位答案为1的值. 比如6位数确 ...

  5. bzoj2811 [Apio2012]Guard

    传送门:http://www.lydsy.com/JudgeOnline/problem.php?id=2811 [题解] 首先我们先把没看到忍者的段去掉,可以用线段树做. 如果剩下的就是K,那么特判 ...

  6. LUOGU P3112 [USACO14DEC]后卫马克Guard Mark

    题目描述 Farmer John and his herd are playing frisbee. Bessie throws the frisbee down the field, but it' ...

  7. [差分][二分][贪心]luogu P3634 [APIO2012]守卫

    题面 https://www.luogu.com.cn/problem/P3634 给m个限制,可以是一段区间中必须有或者必须无忍者 最多有k个忍者,问有多少个位点一定有忍者 分析 首先用差分标记一下 ...

  8. BZOJ 1692: [Usaco2007 Dec]队列变换 [后缀数组 贪心]

    1692: [Usaco2007 Dec]队列变换 Time Limit: 5 Sec  Memory Limit: 64 MBSubmit: 1383  Solved: 582[Submit][St ...

  9. HDOJ 1051. Wooden Sticks 贪心 结构体排序

    Wooden Sticks Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) To ...

随机推荐

  1. 使用VMware12在CentOS7上部署docker实例

    今天下午算是自己搞了一下午才搞出来,对于认为linux是自己死穴的我,现在能搞出来,心里滋味不是一丢丢,哈哈~~~ 算了,废话不多说,直接上图!步骤如下: 1.在安装好VMware12并安装好了cen ...

  2. angular -——组件样式修改不成功

    angular组件样式修改不成功! 自己定义的css可以成功 组件的不行 style在模板字符串里 直接没有 class 是显示的 但是样式不生效 加上面 即可,为什么?我也不太清楚.有知道答案的请回 ...

  3. flask 模型一对多个人理解

    在modle中创建两个模型表 class User(db.Model): id = db.Column(db.Integer,primary_key=True,autoincrement=True) ...

  4. 解决Ajax中IE浏览器缓存问题

    解决Ajax中IE浏览器缓存问题 1.首先,先看一张图.从这张图中我们可以清楚的了解到从请求的发出到解析响应的过程. 2.根据图中的三个节点我们可以使用三种方式解决这个缓存问题(主要是针对ie) 2. ...

  5. Upload-labs 测试笔记

    Upload-labs 测试笔记 By:Mirror王宇阳 2019年11月~ 文件上传解析学习 环境要求 若要自己亲自搭建环境,请按照以下配置环境,方可正常运行每个Pass. 配置 项 配置 描述 ...

  6. call、apply和bind的学习

    相似之处:1.都是用来改变函数的this对象的指向的.2.第一个参数都是this要指向的对象.3.都可以利用后续参数传参. var xw = {  name : "小王",gend ...

  7. Android平台接入OneNET

    1. OneNET简介 中国移动物联网开放平台是由中国移动打造的PaaS物联网开放平台. 平台能够帮助开发者轻松实现设备接入与设备连接,提供综合性的物联网解决方案,实现物联网设备的数据获取,数据存储, ...

  8. vue-autoui自匹配webapi的UI控件

    vue-autoui 是一款基于vue和element扩展的一个自动化UI控件,它主要提供两个控件封装分别是auto-form和auto-grid; 通过这两个控件可以完成大多数的信息输入和查询输出的 ...

  9. JAVA多线程面试必看(转载)

    JAVA多线程和并发基础面试问答 原文链接:http://ifeve.com/java-multi-threading-concurrency-interview-questions-with-ans ...

  10. Java-方法(新手)

    //创建的一个类.public class zy1ri0319 { //公共静态的主方法. public static void main(String[] args){ //调用方法. zy1(); ...