Description

国防部计划用无线网络连接若干个边防哨所。2种不同的通讯技术用来搭建无线网络; 每个边防哨所都要配备无线电收发器;有一些哨所还可以增配卫星电话。 任意两个配备了一条卫星电话线路的哨所(两边都拥有卫星电话)均可以通话,无论 他们相距多远。而只通过无线电收发器通话的哨所之间的距离不能超过D,这是受收发器的功率限制。收发器的功率越高,通话距离D会更远,但同时价格也会更贵。 收发器需要统一购买和安装,所以全部哨所只能选择安装一种型号的收发器。换句话说,每一对哨所之间的通话距离都是同一个D。 你的任务是确定收发器必须的最小通话距离D,使得每一对哨所之间至少有一条通话路径(直接的或者间接的)。

Input

第 1 行:2个整数 S(1<=S<=100)和 P(S<P<=500), S表示可安装的卫星电话的哨 所数,P表示边防哨所的数量。 接下里P行,每行描述一个哨所的平面坐标(x,y),以 km为单位,整数,0<=x,y<=10000。

Output

第1行:1个实数D,表示无线电收发器的最小传输距离。精确到小数点后两位。

Range

对于20%的数据 P=2,S=1 对于另外20%的数据 P=4,S=2 对于100%的数据 1<=S<=100,S<P<=500

Solution

我们可以把这道题抽象一下,能通过收发器连接的哨所看成一个联通块,而卫星电话就代表可以连接联通块的边。所以这题就变成了最小生成树问题,即通过连边构造出P-S个联通块即可。

Code

#include<cmath>
#include<cstdio>
#include<cctype>
#include<cstdlib>
#include<algorithm>
#define int long long
using namespace std;

int m,n,maxn,ans,cnt,sum;
];

struct Node{
    int x,y,dis;
    friend bool operator<(Node a,Node b){
        return a.dis<b.dis;
    }
}edge[];

struct Edge{
    int x,y;
}node[];

int dist(int i,int j){
    return (node[i].x-node[j].x)*(node[i].x-node[j].x)+(node[i].y-node[j].y)*(node[i].y-node[j].y);
}

int find(int x){
    if(father[x]==x) return x;
    father[x]=find(father[x]);
    return father[x];
}

int read(int &x){
    x=;char ch=getchar();
    while(!isdigit(ch)) ch=getchar();
    )+(x<<)+(ch^),ch=getchar();
}

signed main(){
    /*freopen("wireless.in","r",stdin);
    freopen("wireless.out","w",stdout);*/
    read(m),read(n);
    ;i<=n;i++) read(node[i].x),read(node[i].y);
    ;i<=n;i++){
        ;j<=n;j++){
            if(i==j) continue;
            edge[++cnt].x=i,edge[cnt].y=j;
            edge[cnt].dis=dist(i,j);
        }
    }
    sort(edge+,edge++cnt);
    ;
    ;i<=n;i++) father[i]=i;
    ;i<=cnt;i++){
        int r1=find(edge[i].x);
        int r2=find(edge[i].y);
        if(r1!=r2)
            father[r1]=r2,k++;
        if(k+m==n){
            printf("%.2lf",sqrt((double)edge[i].dis));
            fclose(stdin);fclose(stdout);
            ;
        }
    }
    /*for(int i=sum;i;i--){
        m-=2;
        if(have[edge[used[i]].x]) m++;
        if(have[edge[used[i]].y]) m++;
        have[edge[used[i]].x]=have[edge[used[i]].y]=1;
        if(m<0){
            printf("%.2lf",sqrt((double)edge[used[i]].dis));
            //fclose(stdin);fclose(stdout);
            return 0;
        }
    }*/
}

[模拟赛] T1 无线通讯网的更多相关文章

  1. 【洛谷比赛】[LnOI2019]长脖子鹿省选模拟赛 T1 题解

    今天是[LnOI2019]长脖子鹿省选模拟赛的时间,小编表示考的不怎么样,改了半天也只会改第一题,那也先呈上题解吧. T1:P5248 [LnOI2019SP]快速多项式变换(FPT) 一看这题就很手 ...

  2. 20180610模拟赛T1——脱离地牢

    Description 在一个神秘的国度里,年轻的王子Paris与美丽的公主Helen在一起过着幸福的生活.他们都随身带有一块带磁性的阴阳魔法石,身居地狱的魔王Satan早就想着得到这两块石头了,只要 ...

  3. NOIP欢乐模拟赛 T1 解题报告

    小澳的方阵 (matrix.cpp/c/pas) [题目描述] 小澳最近迷上了考古,他发现秦始皇的兵马俑布局十分有特点,热爱钻研的小澳打算在电脑上还原这个伟大的布局. 他努力钻研,发现秦始皇布置兵马俑 ...

  4. [模拟赛] T1 高级打字机

    Description 早苗入手了最新的高级打字机.最新款自然有着与以往不同的功能,那就是它具备撤销功能,厉害吧. 请为这种高级打字机设计一个程序,支持如下3种操作: 1.T x:在文章末尾打下一个小 ...

  5. 2019.2.25 模拟赛T1【集训队作业2018】小Z的礼物

    T1: [集训队作业2018]小Z的礼物 我们发现我们要求的是覆盖所有集合里的元素的期望时间. 设\(t_{i,j}\)表示第一次覆盖第i行第j列的格子的时间,我们要求的是\(max\{ALL\}\) ...

  6. [NOIP2018校模拟赛]T1 阶乘

    题目: 描述 有n个正整数a[i],设它们乘积为p,你可以给p乘上一个正整数q,使p*q刚好为正整数m的阶乘,求m的最小值. 输入 共两行. 第一行一个正整数n. 第二行n个正整数a[i]. 输出 共 ...

  7. [NOIP2018校模拟赛]T1聚会 party

    题目链接: 聚会 分析: 设每个点到1号点的距离为dist_{i},每个点的权值为x_{i},目标点到1号点的距离为dist,权值为x,那么对于每一次查询,我们讨论三种情况: ① 目标家庭在区间左边( ...

  8. 【2019.8.15 慈溪模拟赛 T1】插头(plugin)(二分+贪心)

    二分 首先,可以发现,最后的答案显然满足可二分性,因此我们可以二分答案. 然后,我们只要贪心,就可以验证了. 贪心 不难发现,肯定会优先选择能提供更多插座的排插,且在确定充电器个数的情况下,肯定选择能 ...

  9. 【2019.7.20 NOIP模拟赛 T1】A(A)(暴搜)

    打表+暴搜 这道题目,显然是需要打表的,不过打表的方式可以有很多. 我是打了两个表,分别表示每个数字所需的火柴棒根数以及从一个数字到另一个数字,除了需要去除或加入的火柴棒外,至少需要几根火柴棒. 然后 ...

随机推荐

  1. Typescript 基础应用

    什么是 TypeScript TypeScript 是微软开发的 JavaScript 的超集,TypeScript兼容JavaScript,可以载入JavaScript代码然后运行.TypeScri ...

  2. 重磅︱R+NLP:text2vec包——New 文本分析生态系统 No.1(一,简介)

    每每以为攀得众山小,可.每每又切实来到起点,大牛们,缓缓脚步来俺笔记葩分享一下吧,please~ --------------------------- 词向量的表示主流的有两种方式,一种当然是耳熟能 ...

  3. Red Hat Enterprise Linux 6 “桌面”、“工作站”、“服务器” 版本差异比较

    Red Hat Enterprise Linux 6,共有三个版本.通过安装发现,所谓的"桌面"."工作站"."服务器"这三个版本的区别就在 ...

  4. 芝麻HTTP:Python爬虫实战之爬取百度贴吧帖子

    本篇目标 1.对百度贴吧的任意帖子进行抓取 2.指定是否只抓取楼主发帖内容 3.将抓取到的内容分析并保存到文件 1.URL格式的确定 首先,我们先观察一下百度贴吧的任意一个帖子. 比如:http:// ...

  5. html->html5->css->javascript(js)->jQuery->AJAX->JSON

    首先来讲HTML,html是很多人接触到的第一种编写网页的语言,小编是在大学本科期间的编程课程上接触到html的,小小的几行代码就能编制出精彩绝伦的网页,不禁令人赞叹!HTML的语法自然不用多说,网上 ...

  6. css 超出规定行数自动隐藏

     单行overflow: hidden;text-overflow: ellipsis;white-space: nowrap;  多行(兼容各个浏览器)//通过覆盖最后几个字的形式p{positio ...

  7. 版本控制工具--svn和git的使用(三) -----git的使用(1)

    安装 git官网就有git各个系统的安装包,可以根据自己系统安装相应的安装包.window的git安装包 依据国内网速原因,将安装放到网盘里,链接: https://pan.baidu.com/s/1 ...

  8. Alice and Bob HDU - 4268

    Alice and Bob's game never ends. Today, they introduce a new game. In this game, both of them have N ...

  9. linux和windows通用的路径

    String path=request.getSession().getServletContext().getRealPath("/")+"js" + Sys ...

  10. 【BZOJ1001】狼抓兔子(网络流)

    [BZOJ1001]狼抓兔子(网络流) 题面 Description 现在小朋友们最喜欢的"喜羊羊与灰太狼",话说灰太狼抓羊不到,但抓兔子还是比较在行的, 而且现在的兔子还比较笨, ...