LA 8043. ACM-ICPC World Finals 2017 E. Need for Speed

二分
LA上的题目居然和原题有差别!变成了多组数据
下面这个程序是按原题写的

#include <iostream>
#include <cstdio>
#include <algorithm>

int main() {
  int n, t;
  std::cin >> n >> t;
  
  double d[1000], s[1000];
  for (int i = 0; i < n; i++)
    std::cin >> d[i] >> s[i];
  
  double l = -*std::min_element(s, s + n), r = 1001000;
  while (l + 2e-10 <= r) {
    double mid = l + (r - l) / 2, t_ = 0;
    
    for (int i = 0; i < n; i++)
      t_ += d[i] / (s[i] + mid);
    
    if (t_ < t)
      r = mid;
    else
      l = mid;
  }
  printf("%.9lf\n", l);
  return 0;
}
posted @ 2017-12-28 19:19  Planet6174  阅读(401)  评论(0编辑  收藏  举报