思路:我们考虑由于没有人的区间会覆盖其他人,所以我们将区间按左端点排序,发现如果地盘长度已知,可以贪心地尽量往左放,来判断是否有解,因此做法很简单,就是二分答案,然后O(n)贪心判定,复杂度为O(nlogn)

满分程序:

  1. #include<algorithm>
  2. #include<cstdio>
  3. #include<cmath>
  4. #include<cstring>
  5. #include<iostream>
  6. #define ll long long
  7. const long double eps=1e-;
  8. int n;
  9. struct node{
  10. long double l,r;
  11. }a[];
  12. bool cmp(node q,node w){
  13. if (q.l==w.l) return q.r<w.r;
  14. return q.l<w.l;
  15. }
  16. int read(){
  17. char ch=getchar();int t=,f=;
  18. while (ch<''||ch>''){if (ch=='-') f=-;ch=getchar();}
  19. while (''<=ch&&ch<=''){t=t*+ch-'';ch=getchar();}
  20. return t*f;
  21. }
  22. bool check(long double mid){
  23. long double last=,len=;
  24. for (int i=;i<=n;i++){
  25. len=std::max(a[i].r-std::max(a[i].l,last),(long double)0.0);
  26. if (len<mid) return ;
  27. last=std::max(a[i].l,last)+mid;
  28. }
  29. return ;
  30. }
  31. ll gcd(ll a,ll b){
  32. if (b==) return a;
  33. else return gcd(b,a%b);
  34. }
  35. void getpq(long double x,ll &p,ll &q){
  36. long double mod=1e8,tmp;
  37. p=,q=;
  38. for (int i=;i<=n;i++){
  39. tmp=fabs(x*i-(ll)(x*i+.));
  40. if (tmp<mod)
  41. mod=tmp,q=i,p=(ll)(x*i+.);
  42. }
  43. ll t=gcd(p,q);
  44. p/=t;
  45. q/=t;
  46. }
  47. int main(){
  48. int T=read();
  49. while (T--){
  50. n=read();
  51. for (int i=;i<=n;i++)
  52. a[i].l=read(),a[i].r=read();
  53. std::sort(a+,a++n,cmp);
  54. long double l=,r=1e8;
  55. while (r-l>eps){
  56. long double mid=(l+r)/;
  57. if (check(mid)) l=mid;
  58. else r=mid;
  59. }
  60. ll p,q;
  61. getpq(l,p,q);
  62. printf("%lld/%lld\n",p,q);
  63. }
  64. }

注意:

(1)没开longdouble,这个错误率好像比较小。。

(2)eps开的不够小,这很可能WA

(3)输出的时候,有没有和其他的方案比较一下,谁的误差比较小。

真是个惨痛的教训。。。T_T

XJOI网上同步训练DAY1 T1的更多相关文章

  1. XJOI网上同步训练DAY6 T1

    思路:考试的时候直接想出来了,又有点担心复杂度,不过还是打了,居然是直接A掉,开心啊. 我们发现,Ai<=7,这一定是很重要的条件,我们考虑状态压缩,去枚举路径中出现了哪些数字,然后我们把原来n ...

  2. XJOI网上同步训练DAY5 T1

    思路:考虑得出,最终的集合一定是gcd=1的集合,那么我们枚举n个数中哪个数必须选,然后把它质因数分解,由于质数不会超过9个,可以状态压缩,去得出状态为0的dp值就是答案. #include<c ...

  3. XJOI网上同步训练DAY3 T1

    思路:看来我真是思博了,这么简单的题目居然没想到,而且我对复杂度的判定也有点问题.. 首先我们选了一个位置i的b,那一定只对i和以后的位置造成改变,因此我们可以这样看: 我们从前往后选,发现一个位置的 ...

  4. XJOI网上同步训练DAY2 T1

    [问题描述] 为了迎接校庆月亮中学操场开始施工.不久后操场下发现了很多古墓这些古墓中有很多宝藏.然而学生们逐渐发现自从操场施工之后学校的运气就开始变得特别不好.后来经过调查发现古墓下有一个太守坟由于操 ...

  5. XJOI网上同步训练DAY1 T3

    思路:一开始看到这题的时候想DP,可是发现貌似不行..因为有前缀也有后缀,而且有的后缀会覆盖到现在的前缀,这就不满足无后效性了啊! 但是有个很巧妙的思路:如果我们知道a[i]的最大值,那么p的数量和q ...

  6. XJOI网上同步训练DAY1 T2

    思路:似曾相识?...见http://www.cnblogs.com/qzqzgfy/p/5266874.html 一看时限还是4s!,于是就开开心心地打了70%的分,就是用容斥原理,就可以n^3解决 ...

  7. XJOI网上同步训练DAY5 T3

    就是对于一个数,我们去考虑把t*****减到(t-1)9999*的代价. #include<cstdio> #include<cmath> #include<algori ...

  8. XJOI网上同步测试DAY14 T1

    思路:线段树维护最短路 #include<cstdio> #include<cmath> #include<iostream> #include<algori ...

  9. XJOI网上同步训练DAY6 T2

    思路:记得FJ省队集训好像有过这题,可是我太弱了,根本不懂T_T #include<cstdio> #include<iostream> #include<cmath&g ...

随机推荐

  1. Codeforces 479E Riding in a Lift

    http://codeforces.com/problemset/problem/432/D 题目大意: 给出一栋n层的楼,初始在a层,b层不能去,每次走的距离必须小于当前位置到b的距离,问用电梯来回 ...

  2. LeetCode_Combination Sum II

    Given a collection of candidate numbers (C) and a target number (T), find all unique combinations in ...

  3. 在O(1) 时间删除链表节点

    struct Node { int val; Node * next; }; void deleteNode(Node ** head, Node * target) { assert(head != ...

  4. KEIL 伪指令

    //为了大家查找方便,命令按字母排序:0.ALTNAME 功能: 这一伪指令用来自定义名字,以替换源程序中原来的保留字,替换的保留字均可等效地用于子程序中. 格式: ALTNAME 保留字 自定义名 ...

  5. win10系统加载ahci驱动的操作方案(Win10之家)

    win10系统使用的过程中很多用户会想要加载ahci驱动,但是大部分用户根本不知道怎么操作加载ahci驱动,这样的话很多用户会遇到一些问题,那如果使用的过程中想要加载ahci驱动的话我们应该怎么操作呢 ...

  6. linux 版本家族

    1. 简单的说,在桌面系统上,可分为Debian和RedHat两大分支,然后Debian这一分支到现在比较火的是Ubuntu, RedHat比较火的是Fedora.贴一下它们的版本历史:  fedor ...

  7. 算法导论(第三版)Exercies2.2(插入排序)

    2.2-1: Θ (n3) 2.2-2:插入排序 void selectionSort(int a[], int n) { int i, j, k, key; ; i<n-; i++) { k ...

  8. TCP头分析+面试题

    一.测试程序 我们先用python来写两个测试脚本,非常简单,看代码: 服务端: from socket import * def accept(): sock = socket(AF_INET, S ...

  9. lucene 高亮显示

    原文地址: http://blog.csdn.net/javaman_chen/article/details/8224407 Lucene针对高亮显示功能提供了两种实现方式,分别是Highlight ...

  10. 关于初学者上传文件到github的方法

    转:http://blog.csdn.net/steven6977/article/details/10567719 说来也惭愧,我是最近开始用github,小白一个,昨天研究了一个下午.终于可以上传 ...