社区讨论

悬1元 MnZn 回滚莫队求调 有WA AC TLE

AT_joisc2014_c歴史の研究参与者 1已保存回复 0

讨论操作

快速查看讨论及其快照的属性,并进行相关操作。

当前回复
0 条
当前快照
1 份
快照标识符
@lpdhagxr
此快照首次捕获于
2023/11/25 11:15
2 年前
此快照最后确认于
2023/11/25 13:14
2 年前
查看原帖
马蜂还算小清新,附提交记录
CPP
#include<bits/stdc++.h>
#define int long long
#define endl '\n'
#define ls (now<<1)
#define rs (now<<1|1)
#define P pair<int,int>
#define pb() push_back()
using namespace std;
const int N=2e6+10;
int n,Q,a[N],b[N];
struct qu{
	int l,r,num;
}q[N];
int len;
int bl[N],br[N],belong[N],ansl[N];
bool cmp(qu a,qu b){
	return a.l/len==b.l/len ? a.r<b.r : a.l<b.l;
}
map<int,int>t;
vector<qu>ques[N];
signed main(){
	ios::sync_with_stdio(0);
	cin.tie(0),cout.tie(0);
	cin>>n>>Q;
	for(int i=1;i<=n;i++){
		cin>>a[i];
	}
	len=n/sqrt(Q);
	int num=(n+len-1)/len;
	for(int i=1;i<=num;i++){
		bl[i]=br[i-1]+1;
		br[i]=i*len;
	}
	br[num]=n;
	for(int i=1;i<=num;i++){
		for(int j=bl[i];j<=br[i];j++){
			belong[j]=i;
		}
	}
	for(int i=1;i<=Q;i++){
		cin>>q[i].l>>q[i].r;
		q[i].num=i;
		ques[(q[i].l+len-1)/len+1].push_back(q[i]);
	}
	
	sort(q+1,q+Q+1,cmp);
	int lnow,rnow;

	for(int i=1;i<=Q;i++){
		lnow=br[i]+1;
		rnow=br[i];
		int ans=0,lastans=0;
		t.clear();
		for (auto it : ques[i]){
			if(belong[it.l]==belong[it.r]){//暴力搞
				t.clear();
				for(int j=it.l;j<=it.r;j++){
					t[a[j]]++;
					if(a[j]*t[a[j]]>=ans)ans=a[j]*t[a[j]];
				}
				t.clear();
				ansl[it.num]=ans;
				ans=lastans=0;
			}else{
				ans=lastans;//重置
				while(lnow<br[i]+1){
					lnow++;
					t[a[lnow]]--;
				}
				while(rnow<it.r){//先移动右端点
					rnow++;
					t[a[rnow]]++;
					if(a[rnow]*t[a[rnow]]>=ans)ans=lastans=a[rnow]*t[a[rnow]];
				}
				while(lnow>it.l){//再改左端点
					lnow--;
					t[a[lnow]]++;
					if(a[lnow]*t[a[lnow]]>=ans)ans=a[lnow]*t[a[lnow]];
				}
				ansl[it.num]=ans;
			}
		}
	}
	for(int i=1;i<=Q;i++)cout<<ansl[i]<<"\n";
	return 0;
}

回复

0 条回复,欢迎继续交流。

正在加载回复...