UVA 1615 Highway

题意:

  有一条沿x轴正方向,长为L的高速公路,n个村庄,要求修建最少的公路出口数目,使得每个村庄到出口的距离不大于D。

分析:

  每个村子可建出口的距离是(l-d,r+d)。将所有区间按右端点排序,若需要选择,每次都选区间右端点。

代码:

  

#include <iostream>
#include <cstdio>
#include <algorithm>
#include <cstring>
#include <cmath>
using namespace std;
double l,d;
int n;
struct node
{
double l,r;
}v[100010];
bool cmp(node a,node b)
{
if(a.r==b.r)
return a.l<b.l;
else
return a.r<b.r;
}
int main()
{
double x,y;
while(scanf("%lf",&l)!=EOF)
{
scanf("%lf%d",&d,&n);
int i,j;
for(i=0;i<n;i++)
{
scanf("%lf%lf",&x,&y);
int len=sqrt(d*d-y*y);
v[i].l=max(x-len,0.0);
v[i].r=min(l,x+len);
}
sort(v,v+n,cmp);
int ans=1;
double r=v[0].r;
for(i=1;i<n;i++)
{
if(r>=v[i].l&&r<=v[i].r)
continue;
else
{
ans++;
r=v[i].r;
}
}
printf("%d ",ans);
}
}
原文地址:https://www.cnblogs.com/137033036-wjl/p/4929288.html