评测传送门

Description
最近,R 终于获得了一片他梦寐以求的农场,但如此大的一片农场,想要做好防卫工作可不是一件容易的事。所以 R 购买了 N 个守卫,分别让他们站在一定的位置上(守卫不可移动,同一位置上至多有一个守卫)。但是,安排了所有的守卫之后,R 才发现,守卫们彼此十分厌恶。经 R 研究,当某两个守卫距离≤K,他们就会发生争吵;但是,想要守卫们和解也是不难的——只需要 R 给出的平均工资能使两人满意,他们就会同意和解、成为朋友;当然,如果两个守卫有共同的朋友,他们也会和解成为朋友。R 非常不想守卫们争吵,因此他想找出,在能使所有守卫闭嘴的前提下,平均工资的最小值是多少。

他想到了一个绝妙的方法,但他忙着去 Farm,没时间,所以这个任务就交给你了。
Input
第 1 行为三个数 N, M, K。
接下来 N 行为 N 个守卫的位置,每行包含两个实数 x, y (x≥0, y≥0)。
接下来 M 行,每行三个数,u, v, w,代表若平均工资≥w,则 u 和 v 同意和解。
Output
输出文件有且仅有一行,一个实数 p,代表最小的平均工资。

data range

M≤100000, M≤200000

Attention
1、本题中的距离定义:对于两个守卫 (x1, y1), (x2, y2) ,它们的距离定义为 max{|x1-x2|,|y1-y2|} 。
2、整数均在 int 范围内,实数均在 double 范围内。
3、给定图中可能存在重边。
4、输出结果保留三位小数。

25分思路:

  预处理出发生冲突的守卫编号

  然后依据输入的两个守卫成为friends的最低平均工资连边

  边权即为输入的最低工资

  然后枚举之前预处理出的发生冲突的守卫 求出它们之间的最短路

  这里路长的定义为:经过的所有路径的边权的最大值,而不是所有路径边权相加

  在所有的最短路之间取max即可

正解思路:

  枚举最低平均工资

  发现它可以二分 即若当前最低平均工资满足所有守卫无冲突

  则 r=mid-1寻找更小的 反之....

  二分工资之后怎么判断是否符合题意呢:

  若两个守卫成为朋友的最低工资<=mid 那么连边(用并查集就可以了)

  然后求平面内最近点对(连了线的两点不对答案做贡献)   (这里是最近点对qwq)

  若最近点对之间的距离>k则合题意

我觉得上面辣种求最近点对的思路很好但是我调了很久的code还没好

然后又借鉴了一下wch的想法   我发现也很好啊不用求最近点对了

也是分治 找有没有两点之间的距离小于等于k 直接在solve里面判断

CODE:

 #include<iostream>
#include<cstdio>
#include<algorithm>
#include<cmath>
#define R register
#define go(i,a,b) for(R int i=a;i<=b;i++)
#define M 100001
#define db double
#define inf 210000000.0
using namespace std;
struct node1{db x,y;int id;}a[M],c[M];
struct node2{int u,v;db w;}b[M<<];
int n,m,f[M];
db k;
int find(int x){if(f[x]==x)return x;return f[x]=find(f[x]);}
bool cmp1(node2 x,node2 y){return x.w<y.w;}
bool cmp2(node1 x,node1 y){return x.y<y.y;}
bool cmp3(node1 x,node1 y){return x.x<y.x;}
bool sol(int l,int r)
{
if(l>=r) return ;//边界
int mid=(l+r)>>,ct=;
if(!sol(l,mid)||!sol(mid+,r)) return ;
while(a[l].x+k<a[mid].x) l++;
while(a[r].x-k>a[mid].x) r--;
go(i,l,r) c[++ct]=a[i];
sort(c+,c+ct+,cmp2);
go(i,,ct)
go(j,i+,ct)
{
if(c[j].y-c[i].y>k) break;
if(fabs(c[i].x-c[j].x)<=k&&find(c[i].id)!=find(c[j].id)) return ;
//这里只要判断x 因为已经保证 c[j].y-c[i].y<=k
}
return ;
}
bool ck(int mid)
{
go(i,,n) f[i]=i; //不要落掉这一步啦 写并查集的时候一定要记得!
go(i,,m)
{
if(b[i].w>b[mid].w) break;
f[find(b[i].u)]=find(b[i].v);//注意这里啊 开始写错了找了好久qwq
}
return sol(,n);
}
int main()
{
cin>>n>>m>>k;
go(i,,n) cin>>a[i].x>>a[i].y,a[i].id=i;
sort(a+,a+n+,cmp3);//按x排序
go(i,,m) cin>>b[i].u>>b[i].v>>b[i].w;
sort(b+,b+m+,cmp1);//按w排序
//好像很少写对过二分??初始化 mid+-1什么的总是搞错
//然后这题的二分还不清楚为什么我之前写的不对 要去问一下 然后再写到这里来
int l=,r=m-,mid;//这里要注意l,r的初始化
while(l<=r)
{
mid=(l+r)>>;
if(ck(mid)) {r=mid-;}
else l=mid+;
}
printf("%.3lf",b[l].w);
return ;
}

R的农场 chebnear的更多相关文章

  1. R 的农场 chebnear (二分答案+最近平面点对)

    题面 \(solution:\) 这道题想到二分答案应该是不难的,因为题目是求平均工资的最小值,这个显然具备单调性: 我们设平均工资的最小值为ans,如果我们现在的平均工资x小于ans那么将x带入题目 ...

  2. R的农场

    R的农场 题目描述 最近,R 终于获得了一片他梦寐以求的农场,但如此大的一片农场,想要做好防卫工作可不是一件容易的事.所以 R 购买了 N 个守卫,分别让他们站在一定的位置上(守卫不可移动,同一位置上 ...

  3. 【题解】[CJOI2019Chebnear]

    [题解][CJOI2019Chebnear] 题目描述 给定平面上有\(n\)个仇人,\((x,y) ,x,y \in R^+\) ,\(n\)个人都是仇人关系,而有仇人关系的一对人的切比雪夫距离若\ ...

  4. [原]CentOS7安装Rancher2.1并部署kubernetes (二)---部署kubernetes

    ##################    Rancher v2.1.7  +    Kubernetes 1.13.4  ################ ##################### ...

  5. 利用python进行数据分析2_数据采集与操作

    txt_filename = './files/python_baidu.txt' # 打开文件 file_obj = open(txt_filename, 'r', encoding='utf-8' ...

  6. Django项目:CRM(客户关系管理系统)--81--71PerfectCRM实现CRM项目首页

    {#portal.html#} {## ————————46PerfectCRM实现登陆后页面才能访问————————#} {#{% extends 'king_admin/table_index.h ...

  7. 【BZOJ】3436: 小K的农场

    3436: 小K的农场 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 938  Solved: 417[Submit][Status][Discuss ...

  8. [swustoj 771] 奶牛农场

    奶牛农场 Description 将军有一个用栅栏围成的矩形农场和一只奶牛,在农场的一个角落放有一只矩形的箱子,有一天将军要出门,他就把奶牛用一根绳子套牢,然后将绳子的另一端绑到了那个箱子不靠栅栏的角 ...

  9. 2014.7.7 模拟赛【小K的农场】

    3.小K的农场(farm.pas/cpp/c) [题目描述] 小K在MC里面建立很多很多的农场,总共n个,以至于他自己都忘记了每个农场中种植作物的具体数量了,他只记得一些含糊的信息(共m个),以下列三 ...

随机推荐

  1. 项目上线,php的错误信息必须不让其在页面中显示给客户,

    对于PHP开发者来 说,一旦某个产品投入使用,应该立即将 display_errors选项关闭,以免因为这些错误所透露的路径.数据库连接.数据表等信息而遭到黑客攻击.但是,任何一个产品在投入使用后,都 ...

  2. VMIC

    1. wmic 的简介 wmic -? [全局开关] <命令> 可以使用以下全局开关: /NAMESPACE 别名在其上操作的命名空间的路径. /ROLE 包含别名定义的角色的路径. /N ...

  3. 红帽旗下Linux的版本说明RedHat、CentOS、Fedora、OEL等

    简单总结一下RedHat.CentOS.Fedora Core区别关系: RedHat: 红帽已经被IBM 340亿刀收购了,但是红帽依旧发型自己的RedHat enterprise linux 版本 ...

  4. es6 let关键字

    1.let关键字 var arr = [ ]; for(var i=0; i<10; i++){ arr [i] = function(){ alert(i) } } arr [8](); // ...

  5. AJAX 跨域问题 php

    原生ajax请求方式: var xhr = new XMLHttpRequest(); xhr.open("POST", "http://xxxx.com/demo/b/ ...

  6. 用SQL查询方式显示GROUP BY中的TOP解决方法[转]

    用SQL查询方式显示GROUP BY中的TOP怎样用一个SQL语句来显示 分组后每个组的前几位 比如把一个学校所有学生的成绩按班级分组,再显示每个班级前五名的信息. 班级     学生   成绩 一班 ...

  7. POJ1149_PIGS

    一共有n个猪圈,m个客人,一开始每个猪圈都有一定数量的猪猪.每个客人会打开一些猪圈,带走最多为某一个数量的猪猪,剩下的猪猪可以任意分配在这些开了的猪圈里面,然后重新关上.问所有的客人最多可以带走多少猪 ...

  8. VMware 三种网络模式的区别

    VMware 三种网络模式的区别 VMware 三种网络模式的区别 我们首先说一下VMware的几个虚拟设备 VMnet0:用于虚拟桥接网络下的虚拟交换机 VMnet1:用于虚拟Host-Only网络 ...

  9. 【刷题】BZOJ 2157 旅游

    Description Ray 乐忠于旅游,这次他来到了T 城.T 城是一个水上城市,一共有 N 个景点,有些景点之间会用一座桥连接.为了方便游客到达每个景点但又为了节约成本,T 城的任意两个景点之间 ...

  10. java追加写入txt文件

    整理了下网上的资料,数据追加写入txt文件有三种方式,见下面代码: 方法一: public void method1() { FileWriter fw = null; try { //如果文件存在, ...