# | 제출 시각 | 아이디 | 문제 | 언어 | 결과 | 실행 시간 | 메모리 |
---|---|---|---|---|---|---|---|
917934 | tnun | DNA 돌연변이 (IOI21_dna) | C++17 | 25 ms | 4696 KiB |
이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include <bits/stdc++.h>;
using namespace std;
#define ll long long
#define pb push_back
const int maxn=300006;
int CA[maxn]={0};
int AC[maxn]={0};
int TA[maxn]={0};
int AT[maxn]={0};
int TC[maxn]={0};
int CT[maxn]={0};
void init(string a,string b){
string a1="P"+a;
string b1="P"+b;
for(int i=1;i<=a.length();i++){
CA[i]=CA[i-1];
TA[i]=TA[i-1];
CT[i]=CT[i-1];
TC[i]=TC[i-1];
AT[i]=AT[i-1];
AC[i]=AC[i-1];
if(a1[i]=='A' && b1[i]=='C'){
AC[i]++;
}
if(a1[i]=='T' && b1[i]=='C'){
TC[i]++;
}
if(a1[i]=='A' && b1[i]=='T'){
AT[i]++;
}
if(a1[i]=='T' && b1[i]=='A'){
TA[i]++;
}
if(a1[i]=='C' && b1[i]=='T'){
CT[i]++;
}
if(a1[i]=='C' && b1[i]=='A'){
CA[i]++;
}
}
}
int get_distance(int x,int y){
int sum=0;
int ca1=CA[y]-CA[x-1];
int ac1=AC[y]-AC[x-1];
int ta1=TA[y]-TA[x-1];
int at1=AT[y]-AT[x-1];
int ct1=CT[y]-CT[x-1];
int tc1=TC[y]-TC[x-1];
int temp=min(ca1,ac1);
ca1-=temp; ac1-=temp;
sum+=temp;
temp=min(ta1,at1);
ta1-=temp; at1-=temp;
sum+=temp;
temp=min(tc1,ct1);
tc1-=temp; ct1-=temp;
sum+=temp;
temp=min(tc1,min(ca1,at1));
sum+=temp*2;
tc1-=temp;
ca1-=temp;
at1-=temp;
temp=min(ta1,min(ac1,ct1));
sum+=temp*2;
ta1-=temp;
ac1-=temp;
ct1-=temp;
if(ta1!=0 || at1!=0 || tc1!=0 || ct1!=0 || ac1!=0 || ca1!=0){
return -1;
}else{
return sum;
}
}
컴파일 시 표준 에러 (stderr) 메시지
# | 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... |