Miaomiao's geometry

Source: Internet
Author: User

HDU 4932 bestcoder

 

Problem description

 

There are n point on X-axis. miaomiao wowould like to cover them all by using segments with same length.

There are 2 limits:

1. A point is convered if there is a segments t, the point is the left end or the right end of T.
2. The length of the intersection of any two segments equals zero.

For example, point 2 is convered by [2, 4] and not convered by [1, 3]. [1, 2] and [2, 3] are legal segments, [1, 2] and [3, 4] are legal segments, but [1, 3] and [2, 4] are not (the length of intersection doesn't equals zero), [1, 3] and [3, 4] are not (not the same length ).

Miaomiao wants to maximum the length of segements, please tell her the maximum length of segments.

For your information, the point can't coincidently at the same position. inputthere are several test cases.
There is a number T (t <= 50) on the first line which shows the number of test cases.
For each test cases, there is a number N (3 <= n <= 50) on the first line.
On the second line, there are n integers AI (-1e9 <= AI <= 1e9) shows the position of each point. outputfor each test cases, output a real number shows the answser. please output three digit after the decimal point. sample input3 3 1 2 3 1 2 4 4 1 9 100 10 sample output1.000 2.000 8.000 HintFor the first sample, a legal answer is [1, 2] [2, 3] So the length is 1. for the second sample, a legal answer is [-1, 1] [2, 4] So the answer is 2. for the Thired sample, a legal answer is [-100,108], [], [], [] So the answer is 8.
 1 #include <stdio.h> 2 #include <string.h> 3 #include <algorithm> 4 #include<iostream> 5 #include<math.h> 6  7 using namespace std; 8  9 int main()10 {11     int cas,i,n,right,left;12     double res,a[55],b[120];13     cin>>cas;14     while(cas--)15     {16         cin>>n;17         int j=0;18         for(i=0;i<n;i++)19         {20             cin>>a[i];21         }22         sort(a,a+n);23         for(i=1;i<n;i++)24         {25             b[j++]=a[i]-a[i-1];26             b[j++]=(a[i]-a[i-1]) /2 ;27         }28         sort(b,b+j);29         int flag=0;30         j=j-1;31         res=(double)b[j];32 33         while(1)34         {35             right =0; left=0;36             flag=0;37             for(i=1;i<n;i++)38             {39                 if(i==n-1) continue;40                 if(a[i]-res<a[i-1] && a[i]+res>a[i+1])41                 {42                     flag=1;43                     break;44                 }45                 if(a[i]-res>=a[i-1]) 46                 {47                     if(right==1)48                     {49                         if(a[i]-a[i-1]==res) {left=1; right=0; }50                         else if(a[i]-a[i-1]>=2*res) { left=1; right=0; }51                         else if(a[i]+res<=a[i+1]) { left=0; right=1; }52                         else flag=1;53                     }54                     else { left=1; right=0; }55                 }56                 else if(a[i]+res<=a[i+1]) {57                     right=1;58                     left=0;59                 }60                 61             }62             if(flag==1) {63                 j--;64                 res=b[j];65             }66             else 67             {68                 printf("%.3lf\n",res);69                 break;70             }71         }72     }73     return 0;74 }

 

 

Contact Us

The content source of this page is from Internet, which doesn't represent Alibaba Cloud's opinion; products and services mentioned on that page don't have any relationship with Alibaba Cloud. If the content of the page makes you feel confusing, please write us an email, we will handle the problem within 5 days after receiving your email.

If you find any instances of plagiarism from the community, please send an email to: info-contact@alibabacloud.com and provide relevant evidence. A staff member will contact you within 5 working days.

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.