Submission #1111877

#TimeUsernameProblemLanguageResultExecution timeMemory
1111877ZflopMutating DNA (IOI21_dna)C++17
35 / 100
33 ms6992 KiB
#include <bits/stdc++.h> using namespace std; const int NMAX = (int)1e5 * 2; int sum[NMAX][3][3],N; int get (char a) { if (a == 'A') return 0; if (a == 'C') return 1; return 2; } void init(std::string a, std::string b) { N = a.size(); for (int i = 1; i <= N;++i) { for (int x = 0; x < 3;++x) for (int y = 0; y < 3;++y) sum[i][x][y] += sum[i - 1][x][y]; sum[i][get(a[i - 1])][get(b[i - 1])]++; } } int get_distance(int x, int y) { ++x,++y; int ans = 0; vector<vector<int>>v; for (int a = 0; a < 3;++a) for (int b = a + 1; b < 3;++b) { int one = sum[y][a][b] - sum[x - 1][a][b]; int two = sum[y][b][a] - sum[x - 1][b][a]; int g = min(one,two); if (g != max(one,two)) { if(one > two) v.push_back({a,b,one - two}); else v.push_back({b,a,two - one}); } ans += g; } if (v.size() == 0) return ans; if (v.size() == 1) return -1; if (v.size() == 2) { if (v[0][0] != v[1][1] || v[0][2] != v[1][2]) return -1; return ans + v[0][2]; } if (v.size() == 3) { sort(v.begin(),v.end(),[&](vector<int>a,vector<int>b) {return a[2] < b[2];}); ans += v[0][2] + v[1][2]; //cout << v[0][2] << ' ' << v[1][2] << ' ' << v[2][2] << '\n'; for (int i = 0; i < 3;++i) for (int j = i + 1; j < 3;++j) if (v[i][0] == v[j][1] && v[i][2] != v[j][2]) return -1; return ans; } return 0; }
#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...