码迷,mamicode.com
首页 > 其他好文 > 详细

hdu 4932 Miaomiao's Geometry

时间:2014-08-11 12:07:02      阅读:203      评论:0      收藏:0      [点我收藏+]

标签:style   blog   os   io   for   2014   代码   amp   

被秀智商下限了;

直接代码。。

<span style="font-size:24px;">#include<stdio.h>
#include<string.h>
#include<algorithm>
#include<iostream>
#include<cmath>
using namespace std;
int s[55];
double w[120];
int main()
{
	int a,b,i;
	scanf("%d",&a);
	while(a--)
	{
		scanf("%d",&b);
		for(i=0;i<b;i++)
			scanf("%d",&s[i]);
		sort(s,s+b);
		int cns=0;
		for(i=1;i<b;i++)
		{
			w[cns]=s[i]-s[i-1];
			w[cns+1]=w[cns]/2.0;
			cns+=2;
		}
		sort(w,w+cns);
		int flag;
		cns=cns-1;
		int right,left;
		double res=w[cns];//从大到小找,第一个就是结果
		while(1)
		{
			right=0;
			left=0;
			flag=0;//用来判断取左还是取右。
			for(i=1;i<b;i++)
			{
				if(i==b-1) continue;
				if(s[i]-res<s[i-1] && s[i]+res>s[i+1])//如果有个点左右区间都小于给的长度,跳出找下一个
				{
					flag=1;
					break;
				}
				if(s[i]-res>=s[i-1]) 
				{
					if(right==1)
					{
					    if(s[i]-s[i-1]>=2*res) { left=1; right=0; }	
						else if(s[i]-s[i-1]==res) {left=1; right=0; }//判断是不是共用一段区间
						else if(s[i]+res<=s[i+1]) { left=0; right=1; }
						else flag=1;
					}
					else { left=1; right=0; }
				}
				else if(s[i]+res<=s[i+1]) {
					right=1;
					left=0;
				}
				
			}
			if(flag==1) {
				cns--;
				res=w[cns];
			}
			else 
			{
				printf("%.3lf\n",res);
				break;
			}
		}
	}
	return 0;
}</span>


hdu 4932 Miaomiao's Geometry,布布扣,bubuko.com

hdu 4932 Miaomiao's Geometry

标签:style   blog   os   io   for   2014   代码   amp   

原文地址:http://blog.csdn.net/asuxiexie/article/details/38488475

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!