定长覆盖
时间限制:
2000 ms | 内存限制:
65535 KB
难度:
2
-
描述
-
问题很简单,在一条直线上,坐标从0开始到1000000;现在有n个石子在这条直线上(同一个位置可能有多个石子)
那么用一个定长为m的杆子去覆盖,请问最多能覆盖多少个石子?
-
输入
-
输入有多组数据
第一行有2个整数,n 和 m(n <= 50000,0 < m <= 1000)
第二行有n个整数代表每个石子的位置(所有的数小于50000)
输出
- 每种情况输出一个整数(最多能覆盖的石子数) 样例输入
-
3 2 0 0 1 5 2 0 1 2 4 5
样例输出
-
3 3
来源
- 刘成 上传者
#include<stdio.h> #include<iostream> #include<string.h> #include<algorithm> using namespace std; int a[50005]; int main() { int n,m; while(cin>>n>>m) { int b; memset(a,0,sizeof(a)); for(int i=0;i<n;i++) { cin>>b; a[b]++; } int sum=0; for(int i=0;i<=m;i++) { sum+=a[i]; } int max=sum; for(int i=m+1;i<50005;i++) { sum=sum-a[i-m-1]+a[i]; if(sum>max) max=sum; } printf("%d\n",max); } }
-
输入有多组数据