Submission #1106628

#TimeUsernameProblemLanguageResultExecution timeMemory
1106628kheiraMutating DNA (IOI21_dna)C++17
0 / 100
22 ms5896 KiB
#include <bits/stdc++.h>

using namespace std;

#include "dna.h"
using namespace std;

vector<int> A_a, C_a, T_a;
vector<int> A_b, C_b, T_b;

void init(string a, string b) {
    int n = a.size();
    A_a = C_a = T_a = vector<int>(n + 1, 0);
    A_b = C_b = T_b = vector<int>(n + 1, 0);
    
    for (int i = 1; i <= n; ++i) {
        A_a[i] = A_a[i - 1] + (a[i - 1] == 'A');
        C_a[i] = C_a[i - 1] + (a[i - 1] == 'C');
        T_a[i] = T_a[i - 1] + (a[i - 1] == 'T');
        
        A_b[i] = A_b[i - 1] + (b[i - 1] == 'A');
        C_b[i] = C_b[i - 1] + (b[i - 1] == 'C');
        T_b[i] = T_b[i - 1] + (b[i - 1] == 'T');
    }
}

int get_distance(int x, int y) {
    int a_count_A = A_a[y + 1] - A_a[x];
    int a_count_C = C_a[y + 1] - C_a[x];
    int a_count_T = T_a[y + 1] - T_a[x];
    
    int b_count_A = A_b[y + 1] - A_b[x];
    int b_count_C = C_b[y + 1] - C_b[x];
    int b_count_T = T_b[y + 1] - T_b[x];
    if (a_count_A != b_count_A || a_count_C != b_count_C || a_count_T != b_count_T) {
        return -1;  
    }
    int makanch_AC = abs(a_count_A - b_count_A); 
    int makanch_AT = abs(a_count_A - b_count_T); 
    int makanch_CT = abs(a_count_C - b_count_T); 
    int direct_swaps = makanch_AC / 2 + makanch_AT / 2 + makanch_CT / 2;
    int two_step_swaps = (makanch_AC % 2) + (makanch_AT % 2) + (makanch_CT % 2);
    
    return direct_swaps + 2 * two_step_swaps;
}
#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...