B. The Meeting Place Cannot Be Changed
5 seconds
256 megabytes
standard input
standard output
The main road in Bytecity is a straight line from south to north. Conveniently, there are coordinates measured in meters from the southernmost building in north direction.
At some points on the road there are n friends, and i-th of them is standing at the point xi meters and can move with any speed no greater than vi meters per second in any of the two directions along the road: south or north.
You are to compute the minimum time needed to gather all the n friends at some point on the road. Note that the point they meet at doesn't need to have integer coordinate.
The first line contains single integer n (2 ≤ n ≤ 60 000) — the number of friends.
The second line contains n integers x1, x2, ..., xn (1 ≤ xi ≤ 109) — the current coordinates of the friends, in meters.
The third line contains n integers v1, v2, ..., vn (1 ≤ vi ≤ 109) — the maximum speeds of the friends, in meters per second.
Print the minimum time (in seconds) needed for all the n friends to meet at some point on the road.
Your answer will be considered correct, if its absolute or relative error isn't greater than 10 - 6. Formally, let your answer be a, while jury's answer be b. Your answer will be considered correct if
holds.
3
7 1 3
1 2 1
2.000000000000
4
5 10 3 2
2 3 2 4
1.400000000000
In the first sample, all friends can gather at the point 5 within 2 seconds. In order to achieve this, the first friend should go south all the time at his maximum speed, while the second and the third friends should go north at their maximum speeds.
思路:二分;
二分时间,然后每次检查时求出每个点所能到达的左右的距离,然后求线段的最大重叠。复杂度(n*log^2(n))
或者二分每次检查时求出每个点所能到达的左右的距离,然后维护最小的右端r,和最大的左端l,如果r > l成立复杂度n*log(n);
1 #pragma comment(linker, "/STACK:102400000,102400000")
2 #include<stdio.h>
3 #include<algorithm>
4 #include<iostream>
5 #include<string.h>
6 #include<stdlib.h>
7 #include<queue>
8 #include<map>
9 #include<math.h>
10 #include<vector>
11 const int N = 1e6+6;
12 using namespace std;
13 typedef long long LL;
14 double x[70000];
15 double v[70000];
16 typedef struct node
17 {
18 double val;
19 int k;
20 } ss;
21 bool cmp(node p,node q)
22 {
23 if(p.val == q.val)
24 return p.k > q.k;
25 else return p.val < q.val;
26 }
27 ss ask[70000*2];
28 bool check(double c,int n);
29 int main(void)
30 {
31 int n;
32 scanf("%d",&n);
33 for(int i = 1; i <= n; i++)
34 scanf("%lf",&x[i]);
35 for(int i = 1; i <= n; i++)
36 scanf("%lf",&v[i]);
37 int t = 100;
38 double ll = 0,rr = 1e10;
39 double acc = -1;
40 while(t)
41 {
42 double mid = (ll+rr)/2;
43 if(check(mid,n))
44 {
45 acc = mid;
46 rr = mid;
47 //printf("%lf\n",mid);
48 }
49 else ll = mid;
50 t--;
51 }
52 printf("%.10f\n",acc);
53 return 0;
54 }
55 bool check(double c,int n)
56 {
57 int cn = 0;
58 for(int i = 1; i <= n; i++)
59 {
60 ask[cn].val = max((double)0,x[i] - c*v[i]);
61 ask[cn].k = 1;
62 cn++;
63 ask[cn].val = x[i] + c*v[i];
64 ask[cn].k = -1;
65 cn++;
66 }
67 int sum = 0;
68 sort(ask,ask+cn,cmp);
69 for(int i = 0; i < cn; i++)
70 {
71 sum += ask[i].k;
72 if(sum == n)
73 return true;
74 }
75 return false;
76 }
1 #pragma comment(linker, "/STACK:102400000,102400000")
2 #include<stdio.h>
3 #include<algorithm>
4 #include<iostream>
5 #include<string.h>
6 #include<stdlib.h>
7 #include<queue>
8 #include<map>
9 #include<math.h>
10 #include<vector>
11 const int N = 1e6+6;
12 using namespace std;
13 typedef long long LL;
14 double x[70000];
15 double v[70000];
16 typedef struct node
17 {
18 double val;
19 int k;
20 } ss;
21 bool cmp(node p,node q)
22 {
23 if(p.val == q.val)
24 return p.k > q.k;
25 else return p.val < q.val;
26 }
27 ss ask[70000*2];
28 bool check(double c,int n);
29 int main(void)
30 {
31 int n;
32 scanf("%d",&n);
33 for(int i = 1; i <= n; i++)
34 scanf("%lf",&x[i]);
35 for(int i = 1; i <= n; i++)
36 scanf("%lf",&v[i]);
37 int t = 100;
38 double ll = 0,rr = 1e10;
39 double acc = -1;
40 while(t)
41 {
42 double mid = (ll+rr)/2;
43 if(check(mid,n))
44 {
45 acc = mid;
46 rr = mid;
47 //printf("%lf\n",mid);
48 }
49 else ll = mid;
50 t--;
51 }
52 printf("%.10f\n",acc);
53 return 0;
54 }
55 bool check(double c,int n)
56 {
57 int cn = 0;
58 double maxx = 1e10;
59 double minn = 0;
60 for(int i = 1; i <= n; i++)
61 {
62 minn = max(minn,x[i] - c*v[i]);
63 maxx = min(maxx,x[i] + c*v[i]);
64 }
65 if(maxx >= minn)return true;
66 return false;
67 }
n*log(n)
B. The Meeting Place Cannot Be Changed的更多相关文章
- codeforces 782B The Meeting Place Cannot Be Changed (三分)
The Meeting Place Cannot Be Changed Problem Description The main road in Bytecity is a straight line ...
- code force 403B.B. The Meeting Place Cannot Be Changed
B. The Meeting Place Cannot Be Changed time limit per test 5 seconds memory limit per test 256 megab ...
- Cf Round #403 B. The Meeting Place Cannot Be Changed(二分答案)
The Meeting Place Cannot Be Changed 我发现我最近越来越zz了,md 连调程序都不会了,首先要有想法,之后输出如果和期望的不一样就从输入开始一步一步地调啊,tmd现在 ...
- Codeforces Round #403 (Div. 2, based on Technocup 2017 Finals) B. The Meeting Place Cannot Be Changed
地址:http://codeforces.com/contest/782/problem/B 题目: B. The Meeting Place Cannot Be Changed time limit ...
- AC日记——The Meeting Place Cannot Be Changed codeforces 780b
780B - The Meeting Place Cannot Be Changed 思路: 二分答案: 代码: #include <cstdio> #include <cstrin ...
- Codeforces 782B The Meeting Place Cannot Be Changed(二分答案)
题目链接 The Meeting Place Cannot Be Changed 二分答案即可. check的时候先算出每个点可到达的范围的区间,然后求并集.判断一下是否满足l <= r就好了. ...
- codeforces 782B The Meeting Place Cannot Be Changed+hdu 4355+hdu 2438 (三分)
B. The Meeting Place Cannot Be Change ...
- CodeForce-782B The Meeting Place Cannot Be Changed(高精度二分)
https://vjudge.net/problem/CodeForces-782B B. The Meeting Place Cannot Be Changed time limit per tes ...
- codeforces 782B - The Meeting Place Cannot Be Changed
time limit per test 5 seconds memory limit per test 256 megabytes input standard input output standa ...
随机推荐
- Django创建多对多表关系的三种方式
方式一:全自动(不推荐) 优点:django orm会自动创建第三张表 缺点:只会创建两个表的关系字段,不会再额外添加字段,可扩展性差 class Book(models.Model): # ... ...
- Apache RocketMQ分布式消息传递和流数据平台及大厂面试宝典v4.9.2
概述 **本人博客网站 **IT小神 www.itxiaoshen.com 定义 Apache RocketMQ官网地址 https://rocketmq.apache.org/ Latest rel ...
- 内网穿透—使用 frp 实现内外网互通
前言 什么是内网穿透? 内网穿透,又叫 NET 穿透,是计算机用语.用通俗的说法就是你家里的个人电脑,可以直接被外网的人访问.例如你在公司,不通过远程工具,直接也可以访问到家里的电脑(本文章特指 we ...
- 理解ASP.NET Core - 模型绑定&验证(Model Binding and Validation)
注:本文隶属于<理解ASP.NET Core>系列文章,请查看置顶博客或点击此处查看全文目录 模型绑定 什么是模型绑定?简单说就是将HTTP请求参数绑定到程序方法入参上,该变量可以是简单类 ...
- Git的使用-一个分支完全替换另一个分支
之前公司git分支混乱,今天花时间整理了一下,在合并分支的时候遇到一个问题: 一个很久没有拉取远程代码的分支与master分支合并时,出现冲突之外,还会丢失文件,很头疼,然后找到了下面的方法,可以直接 ...
- java中的collection小结
Collection 来源于Java.util包,是非常实用常用的数据结构!!!!!字面意思就是容器.具体的继承实现关系如下图,先整体有个印象,再依次介绍各个部分的方法,注意事项,以及应用场景. ...
- SpringMVC注解详情
@Component.@Repository @Service.@Controller 看字面含义,很容易却别出其中三个: @Controller 控制层,就是我们的action层 @Service ...
- oralce 存储过程传入 record 类型的参数?
先定义一个 package , package中含有一个 record 类型的变量 create or replace package pkg_record is type emp_record is ...
- GO类型转换
golang []byte转string golang中,字符切片[]byte转换成string最简单的方式是 package main import ( "fmt" _ &quo ...
- CountDownLatch原理
正如每个Java文档所描述的那样,CountDownLatch是一个同步工具类,它允许一个或多个线程一直等待,直到其他线程的操作执行完后再执行.在Java并发中,countdownlatch的概念是一 ...