104382024-04-02 14:03:51111Túlcsorduláscpp17Hibás válasz 70/100193ms15540 KiB
#include <bits/stdc++.h>
using namespace std;

#define int long long

#define MOD 1000000007
#define BASE 256
#define BASE_INV 285156252

signed main(){
	ios::sync_with_stdio(false);
	cin.tie(nullptr);
	int N;
	cin>>N;
	string A,B;
	cin>>A>>B;
	for(char&c:B){
		c='0'+'1'-c;
	}
	vector<int>p(N+1,1),ha(N+1),hb(N+1);
	for(int i=0;i<N;i++){
		p[i+1]=p[i]*BASE%MOD;
		ha[i+1]=(ha[i]*BASE+A[i])%MOD;
		hb[i+1]=(hb[i]*BASE+B[i])%MOD;
	}
	int Q;
	cin>>Q;
	while(Q--){
		int x,y,L;
		cin>>x>>y>>L;
		int l=0,h=L;
		while(l<h){
			int m=(l+h)/2;
			if((ha[x+m+1]-ha[x]*p[m+1]+MOD*MOD)%MOD==(hb[y+m+1]-hb[y]*p[m+1]+MOD*MOD)%MOD){
				l=m+1;
			}
			else{
				h=m;
			}
		}
		cout<<(h==L||A[x+h]=='0'?1:0)<<' ';
	}
	cout<<'\n';
	return 0;
}
RészfeladatÖsszpontTesztVerdiktIdőMemória
subtask10/0
1Elfogadva3ms2004 KiB
2Elfogadva3ms2152 KiB
subtask240/40
3Elfogadva3ms2380 KiB
4Elfogadva3ms2588 KiB
5Elfogadva4ms2588 KiB
6Elfogadva3ms3156 KiB
7Elfogadva4ms2912 KiB
8Elfogadva4ms3112 KiB
9Elfogadva4ms3348 KiB
subtask330/30
10Elfogadva3ms3268 KiB
11Elfogadva19ms3920 KiB
12Elfogadva71ms7776 KiB
13Elfogadva74ms10064 KiB
14Elfogadva131ms14152 KiB
15Elfogadva188ms13868 KiB
16Elfogadva186ms13488 KiB
17Elfogadva182ms14672 KiB
subtask40/30
18Elfogadva8ms5000 KiB
19Elfogadva35ms15180 KiB
20Elfogadva64ms7268 KiB
21Elfogadva112ms12452 KiB
22Elfogadva189ms15300 KiB
23Hibás válasz180ms15540 KiB
24Elfogadva187ms15040 KiB
25Elfogadva180ms14552 KiB
26Hibás válasz188ms15436 KiB
27Elfogadva193ms15400 KiB
28Hibás válasz180ms15396 KiB