This submission is migrated from previous version of oj.uz, which used different machine for grading. This submission may have different result if resubmitted.
#include <bits/stdc++.h>
using namespace std;
#include "dna.h"
const int MX = 1e5 + 10;
map<char, int> mp;
int pref[MX][3][3], sum[MX][3][2];
void init(string a, string b){
int N = a.length();
mp['A'] = 0;
mp['T'] = 1;
mp['C'] = 2;
for(int i = 0; i < N; i++){
sum[i + 1][mp[a[i]]][0]++;
sum[i + 1][mp[b[i]]][1]++;
pref[i + 1][mp[a[i]]][mp[b[i]]]++;
for(int j = 0; j < 3; j++)
for(int k = 0; k < 3; k++)
pref[i + 1][j][k] += pref[i][j][k];
for(int j = 0; j < 3; j++){
pref[i + 1][j][0] += pref[i][j][0];
pref[i + 1][j][1] += pref[i][j][1];
}
}
}
int d(int a, int b){
return a > b ? a - b : b - a;
}
int arr[3][3];
int get_distance(int x, int y){
for(int j = 0; j < 3; j++)
if(sum[y + 1][j][0] - sum[x][j][0] != sum[y + 1][j][1] - sum[x][j][1]) return -1;
for(int j = 0; j < 3; j++)
for(int k = 0; k < 3; k++)
arr[j][k] = pref[y + 1][j][k] - pref[x][j][k];
int ans = 0;
ans += min(arr[0][2], arr[2][0]);
ans += min(arr[0][1], arr[1][0]);
ans += min(arr[1][2], arr[2][1]);
if(d(arr[0][2], arr[2][0]) != d(arr[0][1], arr[1][0]) || d(arr[0][1], arr[1][0]) != d(arr[1][2], arr[2][1]))
return -1;
ans += 2 * d(arr[0][2], arr[2][0]);
return ans;
}
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |