QOJ.ac

QOJ

ID题目提交者结果用时内存语言文件大小提交时间测评时间
#390784#6299. Binary StringOccDreamerTL 0ms11956kbC++144.0kb2024-04-15 21:40:502024-04-15 21:40:51

Judging History

你现在查看的是最新测评结果

  • [2024-04-15 21:40:51]
  • 评测
  • 测评结果:TL
  • 用时:0ms
  • 内存:11956kb
  • [2024-04-15 21:40:50]
  • 提交

answer

//code by Emissary
#include<bits/stdc++.h>

#define vc vector
#define db double
#define fi first
#define se second
#define ll long long
#define mk make_pair
#define pb push_back
#define RI register int
#define PI pair<int,int>
#define ull unsigned long long
#define err cerr << "   -_-   " << endl
#define debug cerr << " ------------------- " << endl

#define input(x) freopen(#x".in","r",stdin)
#define output(x) freopen(#x".out","w",stdout)

#define NO puts("No")
#define YES puts("Yes")

//#define OccDreamer
//#define int long long

using namespace std;

namespace IO{
	inline int read(){
		int X=0, W=0; char ch=getchar();
		while(!isdigit(ch)) W|=ch=='-', ch=getchar();
		while(isdigit(ch)) X=(X<<1)+(X<<3)+(ch^48), ch=getchar();
		return W?-X:X;
	}
	inline void write(int x){
		if(x<0) x=-x, putchar('-');
		if(x>9) write(x/10);
		putchar(x%10+'0');
	}
	inline void sprint(int x){write(x), putchar(32);}
	inline void eprint(int x){write(x), putchar(10);}
}using namespace IO;

const int MAXN = 1e7 + 7;

int topf;
int n, tot;
int nxt[MAXN];

bool mark[MAXN<<1];

char s[MAXN<<1];

struct range{
	int l, r, num, nowtim;
}Q[MAXN], stk[MAXN];

inline void Rotate(int len){
	for(int i=n+1;i<n+len;++i) s[i]=s[i-n];
	for(int i=1;i<=n;++i) s[i]=s[i+len-1];
	return ;
}

inline int Nxt(int x){return x==n?1:x+1;}

inline void solve(){
	scanf("%s",s+1); n=strlen(s+1);
	int fir=0;
	for(int i=1;i<=n;++i) 
		if(s[i]!=s[1]){fir=i; break;}
	if(!fir) return eprint(1);
	Rotate(fir); int sum0=0, sum1=0;
	int nowlen=0, num=s[1]-'0';
	for(int i=1;i<=n;++i){
		if(s[i]-'0'==num) ++nowlen;	
		else{
			if(nowlen>1) sum0+=(num==0)*nowlen, sum1+=(num==1)*nowlen;
			num^=1; nowlen=1;
		}	
	}
	if(nowlen>1) sum0+=(num==0)*nowlen, sum1+=(num==1)*nowlen;
	if(sum1<sum0){
		for(int i=1;i<=n;++i) s[i]^=1;
		reverse(s+1,s+1+n);
	}
	sum0=0, sum1=0;
	nowlen=0, num=s[1]-'0'; int pos=1, lim=0;
	for(int i=1;i<=n;++i){
		if(s[i]-'0'==num) ++nowlen;	
		else{
			if(nowlen>1){
				sum0+=(num==0)*nowlen, sum1+=(num==1)*nowlen;
				if(sum1-sum0<lim) lim=sum1-sum0, pos=i;	
			}
			num^=1; nowlen=1;
		}	
	}
	if(nowlen>1) sum0+=(num==0)*nowlen, sum1+=(num==1)*nowlen;
	Rotate(pos); tot=0;
	nowlen=0, num=s[1]-'0';
	for(int i=1;i<=n;++i){
		if(s[i]-'0'==num) ++nowlen;	
		else{
			if(nowlen>1) Q[++tot]=range{i-nowlen,i-1,num,0};
			num^=1; nowlen=1;
		}	
	}
	int maxn=0;
	if(nowlen>1) Q[++tot]=range{n+1-nowlen,n,num,0};
	for(int i=1;i<=tot;++i){
		if(Q[i].num==1) stk[++topf]=Q[i], stk[topf].l++;
		else{
			Q[i].r--;
			while(topf && Q[i].l<=Q[i].r){
				if(Q[i].nowtim<stk[topf].nowtim) Q[i].r-=stk[topf].nowtim-Q[i].nowtim, Q[i].l-=stk[topf].nowtim-Q[i].nowtim, Q[i].nowtim=stk[topf].nowtim;
				else stk[topf].r+=Q[i].nowtim-stk[topf].nowtim, stk[topf].l+=Q[i].nowtim-stk[topf].nowtim, stk[topf].nowtim=Q[i].nowtim;
				int tim=(Q[i].l-stk[topf].r)/2;
				stk[topf].nowtim+=tim; Q[i].nowtim+=tim; int len=min(stk[topf].r-stk[topf].l+1,Q[i].r-Q[i].l+1);
				if(Q[i].r-Q[i].l+1>=stk[topf].r-stk[topf].l+1){
					Q[i].r-=len;
					Q[i].nowtim+=len; maxn=max(maxn,Q[i].nowtim);
					--topf;
				}
				else{
					stk[topf].l+=len;
					stk[topf].nowtim+=len; maxn=max(maxn,stk[topf].nowtim);
					break;
				}
			}
		}
	}
	int ans=maxn;
	for(int i=1;i<=topf;++i) stk[i].l+=maxn-stk[i].nowtim, stk[i].r+=maxn-stk[i].nowtim;
	for(int i=1;i<=n;++i) mark[i]=0; pos=1; mark[0]=1;
	for(int i=1;i<=topf;++i){
		for(int j=stk[i].l;j<=stk[i].r;++j) mark[j%n==0?n:j%n]=1, pos=j%n==0?n:j%n;
	}
	int las=pos;
	for(int i=Nxt(pos);i!=pos;i=Nxt(i)){
		if(mark[i]) continue;
		mark[i]=mark[las]^1; las=i;	
	}
	for(int i=1;i<=n;++i) s[i]='0'+(int(mark[i]));
	pos=1;
	for(int i=1;i<=n;++i) 
		if(s[i]!=s[1]) {pos=i; break;}
	Rotate(pos); int now=0;
	for(int i=1;i<=n;++i) s[i+n]=s[i];
	for(int i=2;i<=n<<1;++i){
		while(now && s[now+1]!=s[i]) now=nxt[now];
		if(s[now+1]==s[i]) ++now;
		nxt[i]=now;	
	}
	eprint(ans+((n<<1)-nxt[n<<1]));
}

signed main(){
	int t=read();
	while(t--) solve();
	return 0;
}

詳細信息

Test #1:

score: 100
Accepted
time: 0ms
memory: 11956kb

input:

3
1
001001
0001111

output:

1
3
9

result:

ok 3 number(s): "1 3 9"

Test #2:

score: -100
Time Limit Exceeded

input:

262144
000000000000000000
100000000000000000
010000000000000000
110000000000000000
001000000000000000
101000000000000000
011000000000000000
111000000000000000
000100000000000000
100100000000000000
010100000000000000
110100000000000000
001100000000000000
101100000000000000
011100000000000000
11110000...

output:

1
18
18
19
1
1
2
3
1
1
1
3
2
2
3
4
1
1
1
2
1
1
3
4
2
2
2
4
3
3
4
5
1
1
1
2
1
1
2
4
1
1
1
4
3
3
4
5
2
2
2
2
2
2
4
5
3
3
3
5
4
4
5
6
1
1
1
2
1
1
2
3
1
1
1
3
2
2
4
5
1
1
1
2
1
1
4
5
3
3
3
6
4
4
5
6
2
2
2
2
2
2
2
5
2
2
2
5
4
4
5
6
3
3
3
3
3
3
5
6
4
4
4
6
5
5
6
7
1
1
1
2
1
1
2
3
1
1
1
3
2
2
3
5
1
1
1
2
1...

result: