您的位置:首页 > 其它

查找最少标记点 (贪心)

2016-02-29 10:26 190 查看
输入:

N=6

R=10

X={1,7,15,20,30,50}

输出:

3

可从最左边的点开始,距离为R以内的最远的点.因为最左的区域没有覆盖的意义,所以应该尽可能覆盖靠右的点.不断重复此过程.

int N,R;
int X[MAX];

void solve()
{
sort(X,X+N);

int i=0,ans=0;
while(i<N){
//s是没有覆盖的最左的点的位置
int s=X[i++];
while(i<N && X[i]<=s+R)  i++;
//一直向右前进知道距s的距离大于R的点,p是新加上标记的点的位置
int p=X[i--];
while(i<N && X[i]<=p+R)  i++;
//一直向右前进直到距p的距离大于R的点
ans++;
}
printf("%d\n",ans);
}


<<挑战程序设计竞赛>>读后感
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: