45pts 求条,悬赏关注+口头褒奖*1
查看原帖
45pts 求条,悬赏关注+口头褒奖*1
1524111
MonKeySort_ZYczc楼主2025/6/19 18:50

提交记录
有一个很奇怪的想法,感觉篮球杯数据是不是出锅了,目前除了官方两发 unshown 的提交外没有人 AC 诶,而且目前最高分也是 45pts,都是几个比较大的点 WA/TLE,然后 WA 的错法输出结果等等似乎一样
思路就是推柿子然后树状数组维护前缀和

#include<bits/stdc++.h>
using namespace std;
#define int long long
const int N=2e5+10;
int n,m,a[N],c[N][3]; 
inline void upt(int p,int op,int v)
{
	for(;p<=n;p+=p&-p) c[p][op]+=v;
}
inline int que(int p,int op)
{
	int ans=0;
	for(;p;p-=p&-p) ans+=c[p][op];
	return ans; 
}
signed main(){
	ios::sync_with_stdio(0);
	cin.tie(0);cout.tie(0);
	cin>>n>>m;
	for(int i=1;i<=n;i++)
	{
		cin>>a[i];a[i]=min(a[i],3ll);
		if(a[i]<3) upt(i,a[i],1);
	}
	for(int i=1;i<=m;i++)
	{
		int op,x,y;cin>>op>>x>>y;
		if(op==2)
		{
			if(a[x]<3) upt(x,a[x],-1);
			a[x]=min(y,3ll);
			if(a[x]<3) upt(x,a[x],1);
		}
		else
		{
			int s1=que(y,1)-que(x-1,1),s2=que(y,2)-que(x-1,2),len=y-x+1,s3=len-s1-s2;
			cout<<len*(len-1)/2+s1*(s1-1)/2+s1*s3+s1*s2*2<<'\n';
		}
	}
}

2025/6/19 18:50
加载中...