题目传送门:http://poj.org/problem?id=3069
题目大意:一个直线上有N个点。点i的距离是Xi。从这些点中选取若干个加上标记。要求:对于每个点,与其距离为R的范围内必有做标记的点(包括自身)。求至少标记多少点才能满足要求。
题目意思就是让找最少的标记点数,很好理解,贪心嘛,由于最近正在看优先队列,突然感觉这题也能用优先队列做,就实践了一发,也过了;
话不多说上码:
CODE:
#include <bits/stdc++.h> using namespace std; int main()
{
int r, n, num, num0;
priority_queue<int, vector<int>, greater<int> > Q;//优先队列,不过多解释了
while(scanf("%d%d",&r, &n) && (r != - || n != -))
{
while(!Q.empty())
Q.pop();
for(int i = ; i < n; i++)
{
scanf("%d", &num);
Q.push(num);
}
int ans = ;//最终要输出的答案
while(Q.size() > )
{
int mid = Q.top();//此时的mid表示最左边的点
while(Q.size() > )//这层循环就是找那个要标记的点
{
if(mid + r >= Q.top())
{
num0 = Q.top();
Q.pop();
}
else
{
mid = num0;//此时mid就是要标记的那个点
break;
}
} while(Q.size() > )//这层循环呢就是找到右边界
{
if(mid + r >= Q.top())
Q.pop();
else
break;
}
ans++;
}
printf("%d\n",ans);
}
return ;
}
虽说用了优先队列,但是没有过多技术成分,个人感觉比较顺手。。。