(纪中)2414. Social Distancing 2

(File IO): input:socdist2.in output:socdist2.out
时间限制: 1000 ms 空间限制: 262144 KB 具体限制
Goto ProblemSet


题目描述
由于高传染性的牛传染病 C O W V I D − 19 COWVID-19 COWVID19 的爆发, F a r m e r J o h n Farmer John FarmerJohn 非常担忧他的奶牛们的健康。
尽管他尽了最大努力使他的 N N N 头奶牛们 ( 1 ≤ N ≤ 1000 ) (1≤N≤1000) 1N1000践行“社交距离”,还是有许多奶牛不幸染上了疾病。编号为 1 … N 1…N 1N 的奶牛们分别位于一条长直道路上的不同位置(相当于一维数轴),奶牛 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) 0x106 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=minr,minlr

算出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);
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值