O2负优化??
查看原帖
O2负优化??
138106
tgs9311楼主2021/11/3 20:19

O2以后0分,不O2 AC

#include<bits/stdc++.h>
using namespace std;
const int maxn=1e6+100;
int n,ans;
struct ask
{
	int l,r;
};
ask asks[maxn];
bool cmp(ask a,ask b)
{
	return a.l<b.l;
}
int belong[maxn],l[maxn],r[maxn],num,_size;
int a[maxn],add[maxn],lazy[maxn];
void build()
{
	//int n=maxn-1;
	_size=sqrt(n);
	num=n/_size;
	if(n%_size)
	{
		num++;
	}
	for(int i=1;i<=num;i++)
	{
		l[i]=(i-1)*_size+1;
		r[i]=i*_size;
	}
	r[num]=n;
	for(int i=1;i<=n;i++)
	{
		//FAST_IO::read(a[i]);
		belong[i]=i/_size;
		if(i%_size)
		{
			belong[i]++;
		}
		lazy[belong[i]]=max(lazy[belong[i]],a[i]);
	}
} 
int aask(int ls,int rs)
{
	int ans=0;
	int x=belong[ls],y=belong[rs];
	if(x==y)
	{
		for(int i=ls;i<=rs;i++)
		{
			ans=max(ans,a[i]);
		}
	}
	else
	{
		for(int i=ls;i<=r[x];i++)
		{
			ans=max(ans,a[i]);
		}
		for(int i=x+1;i<=y-1;i++)
		{
			ans=max(ans,lazy[i]);
		}
		for(int i=l[y];i<=rs;i++)
		{
			ans=max(ans,a[i]);
		}
	}
	return ans;
}
int update(int x,int k)
{
	a[x]=k;
	lazy[belong[x]]=max(lazy[belong[x]],k);
}

int dp[maxn],maxt,rr[maxn],ytn[maxn];
//查询1~n最大值,单点修改 
int main()
{
	cin>>n;
	for(int i=1;i<=n;i++)
	{
		cin>>asks[i].l>>asks[i].r;
		rr[i]=asks[i].r;
		maxt=max(maxt,asks[i].l);
	}
	sort(asks+1,asks+n+1,cmp);
	sort(rr+1,rr+n+1);
	for(int i=1;i<=n;i++)
	{
		ytn[rr[i]]=i;
	}
	for(int i=1;i<=n;i++)
	{
		asks[i].r=ytn[asks[i].r];
	}
	build(); 
	for(int i=1;i<=n;i++)
	{
		dp[asks[i].r]=max(dp[asks[i].r],aask(1,asks[i].r)+1);
		update(asks[i].r,dp[asks[i].r]);
	}
	for(int i=1;i<maxn;i++)
	{
		ans=max(ans,dp[i]);
	}
	cout<<ans;
}
2021/11/3 20:19
加载中...