(File IO): input:socdist2.in output:socdist2.out
时间限制: 1000 ms 空间限制: 262144 KB 具体限制
Goto ProblemSet
题目描述
由于高传染性的牛传染病
C
O
W
V
I
D
−
19
COWVID-19
COWVID−19 的爆发,
F
a
r
m
e
r
J
o
h
n
Farmer John
FarmerJohn 非常担忧他的奶牛们的健康。
尽管他尽了最大努力使他的
N
N
N 头奶牛们
(
1
≤
N
≤
1000
)
(1≤N≤1000)
(1≤N≤1000)践行“社交距离”,还是有许多奶牛不幸染上了疾病。编号为
1
…
N
1…N
1…N 的奶牛们分别位于一条长直道路上的不同位置(相当于一维数轴),奶牛
i
i
i位于位置
x
i
xi
xi。
F
a
r
m
e
r
J
o
h
n
Farmer John
FarmerJohn 知道存在一个半径
R
R
R,任何与一头被感染的奶牛距离不超过
R
R
R 单位的奶牛也会被感染(然后会传染给与其距离
R
R
R 单位内的奶牛,以此类推)。
不幸的是,
F
a
r
m
e
r
J
o
h
n
Farmer John
FarmerJohn 并不确切知道
R
R
R 的值。他只知道他的哪些奶牛被感染了。给定这个数据,求出起初感染疾病的奶牛的最小数量。
输入
输入的第一行包含
N
N
N。以下
N
N
N 行每行用两个整数
x
x
x 和
s
s
s 描述一头奶牛,其中
x
x
x 为位置
(
0
≤
x
≤
1
0
6
)
(0≤x≤10^6)
(0≤x≤106),
s
s
s 为
0
0
0 表示健康的奶牛,
1
1
1 表示染病的奶牛,并且所有可能因传播而染病的奶牛均已染病。
输出
输出在疾病开始传播之前已经得病的奶牛的最小数量。
样例输入
6
7 1
1 1
15 1
3 1
10 0
6 1
样例输出
3
数据范围限制
提示
在这个例子中,我们知道
R
<
3
R<3
R<3,否则位于位置 7 的奶牛会传染给位于位置
10
10
10 的奶牛。所以,至少
3
3
3 头奶牛初始时已被感染:位于位置
1
1
1 和
3
3
3的两头奶牛中的一头,位于位置
6
6
6 和
7
7
7 的两头奶牛中的一头,以及位于位置
15
15
15 的奶牛。
解题思路
我们现在要先求出
r
r
r,然后去求最终答案
d
d
d。。
先把所有没感染的牛存下来,然后枚举他们,
l
e
f
t
left
left和
r
i
g
h
t
right
right从枚举的位置开始向两边扩展,直到遇到一个被感染的牛,
r
=
m
i
n
(
r
,
m
i
n
(
没
感
染
的
牛
的
位
置
−
l
,
r
−
没
感
染
的
牛
的
位
置
)
r=min(r,min(没感染的牛的位置-l,r-没感染的牛的位置)
r=min(r,min(没感染的牛的位置−l,r−没感染的牛的位置)
算出r后我们枚举每一个点(不止是那 n n n个有牛的点),令被感染的区域大小为 v a va va,若遇到一个被感染的牛,判断一下,如果 v a < = 0 va<=0 va<=0, a n s + + ans++ ans++,然后无论 v a va va是否 < = 0 <=0 <=0,把 v a va va负为 r r r。若没遇到被感染的牛, v a − − va-- va−−。
最后输出 v a va va就行啦!!!!
代码
#include<iostream>
#include<cstring>
#include<string>
#include<cstdio>
#include<algorithm>
#include<iomanip>
#include<cmath>
using namespace std;
int a[1000010],b[1010],x,n,y,r,ans,maxn,minn,va,t,l,d;
int main(){
freopen("socdist2.in","r",stdin);
freopen("socdist2.out","w",stdout);
scanf("%d",&n);
minn=2147480000;
for(int i=1;i<=n;i++)
{
scanf("%d%d",&x,&y);
if(y==1)
a[x]=2;
if(y==0)
{
a[x]=1;
b[++t]=x;
}
maxn=max(maxn,x);
minn=min(minn,x);
}
sort(b+1,b+t+1);
d=2147480000;
for(int i=1;i<=t;i++)
{
l=b[i],r=b[i];
while(a[l]!=2)
{
l--;
if(l<minn)
{
l=-1000001;
break;
}
}
while(a[r]!=2)
{
r++;
if(r>maxn)
{
r=1000001;
break;
}
}
d=min(d,min(b[i]-l,r-b[i]));
}
d-=1;
for(int i=minn;i<=maxn;i++)
{
if(a[i]==2)
{
if(va<=0)
ans++;
va=d;
}
else
va--;
}
printf("%d",ans);
}