题意:一些石头排成一条线,第一个和最后一个不能去掉,其余的共可以去掉m块,要使去掉后石头间距的最小值最大。
这种数学题理解起来真不容易,不过想好了算法就好做了。
代码如下
#include<stdio.h>
#include<math.h>
int a[50005];
int b[50005];
int cmp(const void *a,const void *b)
{
return *(int *)a-*(int *)b;
}
void main()
{
int i,L,N,M,high,low,mid,count;
while(scanf("%d%d%d",&L,&N,&M)!=EOF)
{
for(i=1;i<=N;i++)
scanf("%d",&a[i]);
qsort(&a[1],N,sizeof(int),cmp);
a[N+1]=L;a[0]=0;
for(i=N+1;i>=1;i--)
a[i]=a[i]-a[i-1];
high=L;
low=0;
while(low<=high)
{
count=0;
mid=(low+high)/2;
for(i=1;i<=N+1;i++)
b[i]=a[i];
for(i=1;i<=N;i++)
if(b[i]<mid)
{
count++;
b[i+1]+=b[i];
}
if(b[N+1]<mid)
count++;
if(count<=M)
low=mid+1;
else
high=mid-1;
}
printf("%d\n",high);
}
}