ZOJ1360 POJ1328 Radar Installation, 贪心

首先, 输入的时候就可以判断是否可行.

然后, 我们根据每个点, 确定x轴上的区间, 使得任何雷达站设置到这个区间里都可以探测到这个点, 可以用勾股定理来求出这个区间.

然后我们按照这些区间的左端点排序.

对于相邻的两个区间, 有两种情况, 一是前一区间嵌套后一区间, 二是相交或相离.

贪心主要是每一次都确定最右端点


/*******************************************************************************
 # Author : Neo Fung
 # Email : [email protected]
 # Last modified: 2012-02-13 21:12
 # Filename: ZOJ1360 POJ1328 Radar Installation.cpp
 # Description : 
 ******************************************************************************/
#ifdef _MSC_VER
#define DEBUG
#define _CRT_SECURE_NO_DEPRECATE
#endif

#include <fstream>
#include <stdio.h>
#include <iostream>
#include <string.h>
#include <string>
#include <limits.h>
#include <algorithm>
#include <math.h>
#include <numeric>
#include <functional>
#include <ctype.h>
#define MAX 100010
#define EPS 1e-6
using namespace std;

// 点的定义
struct POINT{
  double l,r;
  bool operator<(const POINT &t) const
  {
    return l<t.l;
  }
}point[MAX];

int func(const double &d,const int &n)
{
	int ans=1;
	double pre=point[0].r;
	for(int i=1;i<n;++i)
		if(point[i].l-pre>EPS)  //前一区间没有嵌套后一区间
		{
			++ans;
			pre=point[i].r;
		}
    else if(point[i].r-pre<EPS) //前一区间嵌套了后一区间
      pre=point[i].r;
	return ans;
}

int main(void)
{
#ifdef DEBUG  
  freopen("../stdin.txt","r",stdin);
  freopen("../stdout.txt","w",stdout); 
#endif  

	int ncases=1,n,d;
	double x,y;

	while(scanf("%d%d",&n,&d)&&(n||d))
	{
		bool flag=true;
		for(int i=0;i<n;++i)
		{
			scanf("%lf%lf",&x,&y);
			if(flag && y-d*1.0<EPS)
			{
				double temp=sqrt(d*d-y*y);
				point[i].l=x-temp;
				point[i].r=x+temp;
			}
			else
				flag=false;
		}
		if(!flag)
    {
			printf("Case %d: -1\n",ncases++);
      continue;
    }

		sort(point,point+n);
		int ans=func(d,n);
		printf("Case %d: %d\n",ncases++,ans);
	}

  return 0;
}


你可能感兴趣的:(struct,email,360)