• POJ 1328 安装雷达 (贪心)


    <题目链接>

    题目大意:

    以x轴为分界,y>0部分为海,y<0部分为陆地,给出一些岛屿坐标(在海中),再给出雷达可达到范围,雷达只可以安在陆地上,问最少多少雷达可以覆盖所以岛屿

    解题思路:

    以岛屿为圆心r为半径画一个圆(记为圆O),于是只要雷达在这个圆里那么这个岛屿就能被覆盖。而从前面的分析可知,雷达必然要布置在x轴上,所以雷达肯定放在圆O与x轴的那段交线区间上

    所以我们可以将所有的岛屿对应的这段区间记录下来,然后就是将这些区间的右端点从小到大排序,然后就是贪心的从左到右安排雷达,记录当前所安排的最右边的雷达的坐标,然后判断当前区间是否包含这个坐标,如果没有,就在这个区间的右端新建一个雷达。

    #include <cstdio>
    #include <cmath>
    #include <algorithm>
    using namespace std;
    using namespace std;
    
    const int N = 1e3+5;
    int n,R;
    
    struct Node{
        int x,y;
        double l,r;
        Node(int _x=0,int _y=0):x(_x),y(_y){}
        bool operator < (const Node &tmp)const{
            return r<tmp.r;     //按r排序
        }
    }node[N];
    
    int main(){
        int ncase=0;
        while(~scanf("%d%d",&n,&R),n||R){
            bool fp=true;
            for(int i=1;i<=n;i++){
                scanf("%d%d",&node[i].x,&node[i].y);
                if(node[i].y>R)fp=false;
                double tmp=(double)sqrt(R*R*1.0-node[i].y*node[i].y*1.0);     //得到如果要覆盖这个点的话,雷达所需呀在的区域
                node[i].l=(double)(node[i].x-tmp);node[i].r=(double)(node[i].x+tmp);
            }if(!fp){ printf("Case %d: -1
    ",++ncase);continue; }
            sort(node+1,node+1+n);
            double loc=node[1].r;int ans=1;
            for(int i=2;i<=n;i++){    
                if(node[i].l>loc)ans++,loc=node[i].r;
            }
            printf("Case %d: %d
    ",++ncase,ans);
        }
    }


    作者:is_ok
    出处:http://www.cnblogs.com/00isok/
    本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。

  • 相关阅读:
    Spring系列-JDBC实例
    postman-记录cookies信息
    根据URL获取参数值得出json结果集,对外给一个接口让别人调用
    linux 软硬链接
    第一个shell程序
    Argparse简易教程
    SQLAlchemy 教程 —— 基础入门篇
    人机对战初体验—四子棋游戏
    python的Flask 介绍
    python的项目结构
  • 原文地址:https://www.cnblogs.com/00isok/p/8687949.html
Copyright © 2020-2023  润新知