码迷,mamicode.com
首页 > 其他好文 > 详细

POJ3069:Saruman's Army

时间:2017-04-03 16:01:16      阅读:177      评论:0      收藏:0      [点我收藏+]

标签:.com   pos   使用   个数   images   更新   math   names   贪心   

 题目链接:http://poj.org/problem?id=3069

贪心

使用两个标志,一个边界点,一个当前比较点即可不断重复更新所需的点个数

挑战程序设计竞赛原文:

技术分享 

 

代码:

 1 #include<cstdio>
 2 #include<cstdlib>
 3 #include<cmath>
 4 #include<memory.h>
 5 #include<algorithm>
 6 #define MAXN 1010
 7 #define INF 0x3f3f3f
 8 using namespace std;
 9 
10 int n,r;
11 int pos[1010];
12 
13 int main()
14 {
15     while(scanf("%d %d",&r,&n)&&(r>=0||n>=0))
16     {
17         memset(pos,0,(MAXN-1)*sizeof(int));
18         for(int i=1;i<=n;i++)
19         {
20             scanf("%d",&pos[i]);
21         }
22         pos[n+1]=INF;
23         sort(pos+1,pos+n+1);
24         int ans=0;
25         int initpos=pos[1];
26         int boundpos=pos[1];
27         for(int i=2;i<=n+1;i++)
28         {
29             if(pos[i]-boundpos<=r)
30                 initpos=pos[i];
31             else
32             {
33                 if(pos[i]-initpos<=r)
34                     continue;
35                 else
36                 {
37                     ans++;
38                     boundpos=pos[i];
39                     initpos=pos[i];
40                 }
41             }
42         }
43         printf("%d\n",ans);
44     }
45     return 0;
46 }

 

POJ3069:Saruman's Army

标签:.com   pos   使用   个数   images   更新   math   names   贪心   

原文地址:http://www.cnblogs.com/bolderic/p/6662124.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!