【codeforces 782B】The Meeting Place Cannot Be Changed
【题目链接】:http://codeforces.com/contest/782/problem/B
【题意】 
 
每个人都有一个速度,只能往上走或往下走; 
然后让你找一个地方,所有人都能够在t时间内到达; 
让t最小.
【题解】 
 
很明显的二分了; 
二分时间t; 
对于某个时间t,这个人都有一个能够到达的唯一区间 
[x[i]-v*t..x[i]+v*t] 
如果所有人的区间都有交集. 
那么就能在那些交集里面随便选一个点了; 
区间的交集可以用 
最大的左端点小于等于最小的右端点这个依据来判断是否存在 
想让答案的精度高一点,就让程序的二分多做几次就好; 
固定200次就够了 
 
【完整代码】
#include <bits/stdc++.h>
using namespace std;
#define lson l,m,rt<<1
#define rson m+1,r,rt<<1|1
#define LL long long
#define rep1(i,a,b) for (int i = a;i <= b;i++)
#define rep2(i,a,b) for (int i = a;i >= b;i--)
#define mp make_pair
#define pb push_back
#define fi first
#define se second
#define rei(x) scanf("%d",&x)
#define rel(x) scanf("%lld",&x)
typedef pair<int, int> pii;
typedef pair<LL, LL> pll;
const int dx[9] = { 0,1,-1,0,0,-1,-1,1,1 };
const int dy[9] = { 0,0,0,-1,1,-1,1,-1,1 };
const double pi = acos(-1.0);
const int N = 6e4+100;
int x[N], v[N];
int n;
int main()
{
    //freopen("F:\\rush.txt", "r", stdin);
    rei(n);
    rep1(i, 1, n)
        rei(x[i]);
    rep1(i, 1, n)
        rei(v[i]);
    double l = 0, r = 1e9 + 100,ans = 0;
    rep1(j,1,200)
    {
        double m = (l + r) / 2;
        double ll = -1e18, rr = 1e18;
        rep1(i, 1, n)
        {
            double t1 = x[i] - m*v[i], t2 = x[i] + m*v[i];
            ll = max(ll, t1), rr = min(rr, t2);
        }
        if (ll <= rr)
        {
            ans = m;
            r = m;
        }
        else
            l = m;
    }
    printf("%.12lf\n", ans);
    return 0;
}【codeforces 782B】The Meeting Place Cannot Be Changed的更多相关文章
- Codeforces 782B:The Meeting Place Cannot Be Changed(三分搜索)
		http://codeforces.com/contest/782/problem/B 题意:有n个人,每个人有一个位置和速度,现在要让这n个人都走到同一个位置,问最少需要的时间是多少. 思路:看上去 ... 
- 【codeforces 415D】Mashmokh and ACM(普通dp)
		[codeforces 415D]Mashmokh and ACM 题意:美丽数列定义:对于数列中的每一个i都满足:arr[i+1]%arr[i]==0 输入n,k(1<=n,k<=200 ... 
- 【55.70%】【codeforces 557A】Ilya and Diplomas
		time limit per test1 second memory limit per test256 megabytes inputstandard input outputstandard ou ... 
- 【codeforces 707E】Garlands
		[题目链接]:http://codeforces.com/contest/707/problem/E [题意] 给你一个n*m的方阵; 里面有k个联通块; 这k个联通块,每个连通块里面都是灯; 给你q ... 
- 【codeforces 707C】Pythagorean Triples
		[题目链接]:http://codeforces.com/contest/707/problem/C [题意] 给你一个数字n; 问你这个数字是不是某个三角形的一条边; 如果是让你输出另外两条边的大小 ... 
- 【codeforces 709D】Recover the String
		[题目链接]:http://codeforces.com/problemset/problem/709/D [题意] 给你一个序列; 给出01子列和10子列和00子列以及11子列的个数; 然后让你输出 ... 
- 【codeforces 709B】Checkpoints
		[题目链接]:http://codeforces.com/contest/709/problem/B [题意] 让你从起点开始走过n-1个点(至少n-1个) 问你最少走多远; [题解] 肯定不多走啊; ... 
- 【codeforces 709C】Letters Cyclic Shift
		[题目链接]:http://codeforces.com/contest/709/problem/C [题意] 让你改变一个字符串的子集(连续的一段); ->这一段的每个字符的字母都变成之前的一 ... 
- 【Codeforces 429D】 Tricky Function
		[题目链接] http://codeforces.com/problemset/problem/429/D [算法] 令Si = A1 + A2 + ... + Ai(A的前缀和) 则g(i,j) = ... 
随机推荐
- web前端背景介绍
			Internet:是一个全球性的计算机互联网络,中文名称“因特网”.“国际互联网”.“网际网”等等: Internet提供的服务:http.ftp.Telnet.email.www.bbs等等: 基本 ... 
- COGS——C2098. Asm.Def的病毒
			http://www.cogs.pro/cogs/problem/problem.php?pid=2098 ★☆ 输入文件:asm_virus.in 输出文件:asm_virus.out ... 
- 学习easyui疑问(三)
			今天我学习easyui中碰到的还有一问题是:怎样创建一个表格? 首先,在easyui中文官网上提供的这样一种定义方式: <!--table--> <table id="tt ... 
- 【Codeforces Round #301 (Div. 2) C】 Ice Cave
			[链接] 我是链接,点我呀:) [题意] 给你一个n*m的地图. 每个地图为0的时候可以安全走过,且走过后变成1. (一定要离开之后才会变成1) 而为1的则走过之后会掉入下一层. 你一开始在初始位置( ... 
- 【AtCoder Beginner Contest 074 B】Collecting Balls (Easy Version)
			[链接]h在这里写链接 [题意] 看懂题目之后就会发现是道大水题. [题解] 在这里写题解 [错的次数] 0 [反思] 在这了写反思 [代码] #include <bits/stdc++.h&g ... 
- CNTK 搞深度学习-1
			CNTK 搞深度学习 Computational Network Toolkit (CNTK) 是微软出品的开源深度学习工具包.本文介绍CNTK的基本内容,如何写CNTK的网络定义语言,以及跑通一个简 ... 
- 三、链路追踪系统 zipkin
			一.构建项目 用到的依赖直接看pom.xml的注释吧 <?xml version="1.0" encoding="UTF-8"?> <proj ... 
- C++利用SOAP开发WebService
			// soapconsole.cpp : Defines the entry point for the console application.// #include "stdafx.h& ... 
- Swift--使图片360° 周期旋转
			UIImageView+Extension.swift import UIKit extension UIImageView { // 360度旋转图片 func rotate360Degree() ... 
- bc -l 对于 %取模计算出错
			https://yq.aliyun.com/articles/279384 expr % expr The result of the expression is the "rema ... 
