文章
5
粉丝
409
获赞
7
访问
52.3k
思路:计算所有未被照亮的米所需要的灯数量。
#include<iostream>
#include<vector>
using namespace std;
int main()
{
int n,m,k;
while(cin>>n>>m>>k)
{
vector<int> pos(m);
for(int i=0;i<m;i++)
{
cin>>pos[i];
}
int s = 1,ans = 0,r = 2*k+1;
for(int i=0;i<m;i++)
{
int e = pos[i]-k;
if(e > s)
ans += (e-s)/r + ((e-s)%r!=0);
s = pos[i] + k + 1;
}
if( n + 1 > s)
ans += (n+1-s)/r + ((n+1-s)%r!=0);
cout<<ans<<endl;
}
}
题意里有个坑,照亮(第)X-K米到(第)X+K实际上是2K+1的距离。
登录后发布评论
怎么会是2*K+1呢 画图还是2*K啊