Submission #437885

#TimeUsernameProblemLanguageResultExecution timeMemory
437885HaidaraMutating DNA (IOI21_dna)C++17
Compilation error
0 ms0 KiB
/* * * * * * * * * * * ID: Haidara * * LANG: C++17 * * PROB: * * * * * * * * * * */ #include<bits/stdc++.h> #define fast ios_base::sync_with_stdio(false);cin.tie(NULL);cout.tie(NULL); #define rep(i,x,n) for(int i=x;i<n;i++) #define FOR(i,n) rep(i,0,n) #define per(i,x,n) for(int i=x;i>n;i--) #define ROF(i,x) for(int i=x;i>=0;i--) #define v(i) vector< i > #define p(i,j) pair< i , j > #define pii pair<int,int> #define m(i,j) map< i , j > #define pq(i) priority_queue< i > #define ff first #define all(x) x.begin(),x.end() #define ss second #define pp push_back using namespace std; const int mod=1e9+7; const int maxn=100100; int st[3][2][maxn*4]; string str[2]; int n; int idx; void build(int l=1,int r=n,int inx=1) { if(l==r) { if(str[idx][l]=='T') st[2][idx][inx]=1; if(str[idx][l]=='C') st[2][idx][inx]=1; if(str[idx][l]=='A') st[2][idx][inx]=1; return ; } int mid=l+(r-l)/2; build(l,mid,inx*2); build(mid+1,r,inx*2+1); FOR(i,3) st[i][idx][inx]=st[i][idx][inx*2]+st[i][idx][inx*2+1]; return ; } int f[3],s[3]; void query(int ql,int qr,int l=1,int r=n,int inx=1) { if(ql<=l&&r<=qr) { FOR(i,3) f[i]+=st[i][0][inx],s[i]+=st[i][1][inx]; return ; } if(l>qr||r<ql) return ; int mid=l+(r-l)/2; query(ql,qr,l,mid,inx*2); query(ql,qr,mid+1,r,inx*2+1); return ; } void init(string a, string b) { str[0]=a; str[1]=b; } int get_distance(int x, int y) { x++,y++; FOR(i,3) f[i]=s[i]=0; int ans=y-x; query(x,y); FOR(i,3) if(f[i]!=s[i]) ans=-1; return ans; } int main() { int n, q; assert(scanf("%d %d", &n, &q) == 2); char A[n+1], B[n+1]; assert(scanf("%s", A) == 1); assert(scanf("%s", B) == 1); std::string a = std::string(A); std::string b = std::string(B); std::vector<int> x(q), y(q); for (int i = 0; i < q; i++) { assert(scanf("%d %d", &x[i], &y[i]) == 2); } fclose(stdin); std::vector<int> results(q); init(a, b); for (int i = 0; i < q; i++) { results[i] = get_distance(x[i], y[i]); } for (int i = 0; i < q; i++) { printf("%d\n", results[i]); } fclose(stdout); return 0; }

Compilation message (stderr)

/usr/bin/ld: /tmp/ccqXPUNq.o: in function `main':
grader.cpp:(.text.startup+0x0): multiple definition of `main'; /tmp/ccw8qrdr.o:dna.cpp:(.text.startup+0x0): first defined here
collect2: error: ld returned 1 exit status