zoukankan      html  css  js  c++  java
  • 【比赛】HNOI2018 游戏


    考试的时候线段树区间查询的return条件打成了l==r。。。。于是光荣爆20(线段树都不会打了?
    膜博士的题解

    #include<bits/stdc++.h>
    #define ui unsigned int
    #define ll long long
    #define db double
    #define ld long double
    #define ull unsigned long long
    const int MAXN=1000000+10,inf=0x3f3f3f3f;
    int n,m,p,lmtL[MAXN],lmtR[MAXN],L[MAXN],R[MAXN],key[MAXN],stack[MAXN],cnt;
    template<typename T> inline void read(T &x)
    {
    	T data=0,w=1;
    	char ch=0;
    	while(ch!='-'&&(ch<'0'||ch>'9'))ch=getchar();
    	if(ch=='-')w=-1,ch=getchar();
    	while(ch>='0'&&ch<='9')data=((T)data<<3)+((T)data<<1)+(ch^'0'),ch=getchar();
    	x=data*w;
    }
    template<typename T> inline void write(T x,char ch='')
    {
    	if(x<0)putchar('-'),x=-x;
    	if(x>9)write(x/10);
    	putchar(x%10+'0');
    	if(ch!='')putchar(ch);
    }
    template<typename T> inline void chkmin(T &x,T y){x=(y<x?y:x);}
    template<typename T> inline void chkmax(T &x,T y){x=(y>x?y:x);}
    template<typename T> inline T min(T x,T y){return x<y?x:y;}
    template<typename T> inline T max(T x,T y){return x>y?x:y;}
    #define Mid ((l+r)>>1)
    #define ls rt<<1
    #define rs rt<<1|1
    #define lson ls,l,Mid
    #define rson rs,Mid+1,r
    struct Segment_Tree{
    	int Mx[MAXN<<2];
    	inline void PushUp(int rt)
    	{
    		Mx[rt]=max(Mx[ls],Mx[rs]);
    	}
    	inline void Build(int rt,int l,int r)
    	{
    		if(l==r)Mx[rt]=key[l];
    		else Build(lson),Build(rson),PushUp(rt);
    	}
    	inline int Mxquery(int rt,int l,int r,int k)
    	{
    		if(Mx[rt]<=k)return 0;
    		if(l==r)return l;
    		else
    		{
    			if(Mx[rs]>k)return Mxquery(rson,k);
    			else return Mxquery(lson,k);
    		}
    	}
    	inline int Psquery(int rt,int l,int r,int L,int R,int k)
    	{
    		if(L<=l&&r<=R)return Mxquery(rt,l,r,k);
    		int res=0;
    		if(R>Mid)res=Psquery(rson,L,R,k);
    		if(res)return res;
    		if(L<=Mid)res=Psquery(lson,L,R,k);
    		return res;
    	}
    	inline int Query(int L,int R,int k)
    	{
    		if(R<L)return L;
    		int res=Psquery(1,1,n,L,R,k);
    		return res?res+1:L;
    	}
    };
    Segment_Tree T;
    #undef Mid
    #undef ls
    #undef rs
    #undef lson
    #undef rson
    inline void init()
    {
    	T.Build(1,1,n);
    	for(register int i=1;i<=n;++i)
    		if(key[i-1]&&key[i-1]<=i-1)lmtL[i]=i;
    		else lmtL[i]=lmtL[i-1];
    	for(register int i=n;i>=1;--i)
    		if(key[i]&&key[i]>i)lmtR[i]=i;
    		else lmtR[i]=lmtR[i+1];
    	for(register int i=n;i>=1;--i)
    	{
    		L[i]=R[i]=i;
    		L[i]=T.Query(lmtL[i],L[i]-1,R[i]);
    		stack[++cnt]=i;
    		while(cnt&&((L[i]<=key[stack[cnt]]&&key[stack[cnt]]<=R[i])||(!key[stack[cnt]])))
    		{
    			R[i]=stack[--cnt];
    			L[i]=T.Query(lmtL[i],L[i]-1,R[i]);
    		}
    	}
    }
    int main()
    {
    	freopen("game.in","r",stdin);
    	freopen("game.out","w",stdout);
    	read(n);read(m);read(p);
    	for(register int i=1;i<=m;++i)
    	{
    		int x,y;
    		read(x);read(y);
    		key[x]=y;
    	}
    	key[0]=-inf,key[n]=inf;
    	init();
    	while(p--)
    	{
    		int s,t;
    		read(s);read(t);
    		if(L[s]<=t&&t<=R[s])puts("YES");
    		else puts("NO");
    	}
    	return 0;
    }
    
  • 相关阅读:
    最大团问题
    树的重心与相关性质
    2020年牛客算法入门课练习赛3 B
    牛客练习赛66 E
    浅谈后缀数组SA
    [随机化算法] 听天由命?浅谈Simulate Anneal模拟退火算法
    “优美的暴力”——树上启发式合并
    [线段树系列] LCT打延迟标记的正确姿势
    [Tarjan系列] Tarjan算法与有向图的SCC
    [Tarjan系列] 无向图e-DCC和v-DCC的缩点
  • 原文地址:https://www.cnblogs.com/hongyj/p/8907501.html
Copyright © 2011-2022 走看看