Submission #441076

#TimeUsernameProblemLanguageResultExecution timeMemory
441076MetalPowerMutating DNA (IOI21_dna)C++17
0 / 100
46 ms8056 KiB
#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 timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...