版权声明:转载请注明出处。 https://blog.csdn.net/u014427196/article/details/41685097

http://acm.hdu.edu.cn/showproblem.php?pid=5112

排序之后计算就好 开始用cin超时了

#include<stdio.h>
#include<iostream>
#include<math.h>
#include<stdlib.h>
#include<ctype.h>
#include<algorithm>
#include<vector>
#include<string.h>
#include<queue>
#include<stack>
#include<set>
#include<map>
#include<sstream>
#include<time.h>
#include<utility>
#include<malloc.h>
#include<stdexcept>

using namespace std;

struct q
{
    int t ;
    int dis;
}p[10005];

int t ;
int n;

bool cmp (q a,q b)
{
    return a.t < b.t;
}

int k=1;

int main()
{
    scanf("%d",&t);
    while (t--)
    {
        scanf("%d",&n);
        for(int i=1;i<=n;i++)
            scanf("%d %d",&p[i].t,&p[i].dis);
        sort(p+1,p+1+n,cmp);

        double ans = (p[2].dis - p[1].dis) * 1.0 / ( p[2].t - p[1].t);

        for(int i=3;i<=n;i++)
        {
            ans = max (ans ,double ( abs( (p[i].dis-p[i-1].dis) )*1.0 / (p[i].t - p[i-1].t) ) );
        }
        printf("Case #%d: %.2lf\n",k++,ans);
    }
    return 0;
}