三分球条
查看原帖
三分球条
831011
Deltary_楼主2024/11/23 21:47
#include<iostream>
#include<cstdio>
#include<vector>
#include<string>
#include<algorithm>
using namespace std;
inline int read(){
	int x=0,f=1;char ch=getchar();
	while(ch<'0'||ch>'9'){
		if(ch=='-') f=-1;ch=getchar();
	} 
	while(ch>='0'&&ch<='9') x=(x<<3)+(x<<1)+(ch-48),ch=getchar();
	return x*f;
}
const int N=2e5+10;
string s;int n,m;
int s1[N],s2[N];
typedef pair<int,pair<int,int> > node;//pl,l,r
//vector <int> fl;
int fl[N];
int tp=0;
int value(int j,int l,int r){
	return min(s1[j]-s1[l-1],s2[r]-s2[j])*2+1;
} 
int solve(int a,int b){
//	int ans=0;
//	int L=lower_bound(fl+1,fl+tp+1,l)-fl;
////	for(int i:fl){
////		if(i<l) continue;
////		if(i>r) break;
////		ans=max(ans,min(s1[i]-s1[l-1],s2[r]-s2[i])*2+1);
////	} 
//	for(int i=L;i<=tp;i++){
//		int j=fl[i];
//		if(j>r) break;
//		ans=max(ans,min(s1[j]-s1[l-1],s2[r]-s2[j])*2+1);
//	}
//	return ans;
	//对于最中间的j  min(s1[j]-s1[l-1],s2[r]-s2[j])*2+1 得max
	//存在j in [L,R] 为[L,R] 内区间最值,[L,j]单调递增 [j,R] 单调递减 三分 
	int L=a,R=b,ans=0;
	int lm,rm,f1,f2,l=lower_bound(fl+1,fl+tp+1,a)-fl,r=upper_bound(fl+1,fl+tp+1,b)-fl-1;
	//cout<<">"<<l<<' '<<r<<endl;
	if(r<l) return 0;
	if(l==r) return value(fl[l],L,R);
	
	while(l<r){
		lm=l+(r-l)/3,rm=r-(r-l)/3;
		f1=value(fl[lm],L,R),f2=value(fl[rm],L,R);
		if(f1>=f2) l=lm+1;
		else r=rm-1;
	}
	//cout<<"<"<<fl[l]<<endl;
	return max(max(f1,f2),max(value(fl[lm],L,R),value(fl[rm],L,R)));
	
	/*
	for(int i=l;i<=r;i++){
		if(value(fl[i],L,R)>ans) ans=value(fl[i],L,R);
	}
	return ans;//暴力 正确 
	*/
}
int main(){
	ios::sync_with_stdio(false);
	cin>>n>>m>>s;
	s="?"+s;
	for(int i=1;i<=n;i++){
		if(s[i]=='/') fl[++tp]=i,s1[i]=s1[i-1],s2[i]=s2[i-1];
		else if(s[i]=='1') s1[i]=s1[i-1]+1,s2[i]=s2[i-1];
		else s2[i]=s2[i-1]+1,s1[i]=s1[i-1];
	}
//	for(int i=1;i<=n;i++){
//		cout<<s1[i]<<" ";
//	}
//	cout<<endl;
//	for(int i=1;i<=n;i++){
//		cout<<s2[i]<<" ";
//	}
//	cout<<endl;
	while(m--){
		int l,r;cin>>l>>r;
		cout<<solve(l,r)<<"\n";
	}
	return 0;
}

暴力是对的, subtask 不过,三分 WA 。

求调谢谢

2024/11/23 21:47
加载中...