제출 #729120

#제출 시각아이디문제언어결과실행 시간메모리
729120vjudge1DNA 돌연변이 (IOI21_dna)C++17
0 / 100
47 ms5320 KiB
#include "dna.h"
#include<bits/stdc++.h>
#define eb emplace_back

std::vector<char>A,B;
std::vector<int>cnt,cntAA,cntTA,cntAB,cntTB,cntCA,cntCB;

void init(std::string a, std::string b) {
    A.eb(' ');
    B.eb(' ');
    cnt.resize(a.size()+1,0);
    cntAA.resize(a.size()+1,0);
    cntAB.resize(a.size()+1,0);
    cntTA.resize(a.size()+1,0);
    cntTB.resize(a.size()+1,0);
    cntCA.resize(a.size()+1,0);
    cntCB.resize(a.size()+1,0);
    for(int i=0;i<a.size();++i){
        A.eb(a[i]);
        B.eb(b[i]);
        if(a[i]!=b[i]){
            cnt[i+1]=cnt[i]+1;
        }
        else{
            cnt[i+1]=cnt[i];
        }
        if(a[i]=='A'){
            cntAA[i+1]=cntAA[i]+1;
            cntTA[i+1]=cntTA[i];
            cntCA[i+1]=cntCA[i];
        }
        else if(a[i]=='T'){
            cntTA[i+1]=cntTA[i]+1;
            cntAA[i+1]=cntAA[i];
            cntCA[i+1]=cntCA[i];
        }
        else{
            cntTA[i+1]=cntTA[i];
            cntAA[i+1]=cntAA[i];
            cntCA[i+1]=cntCA[i]+1;
        }
        if(b[i]=='A'){
            cntAB[i+1]=cntAB[i]+1;
            cntTB[i+1]=cntTB[i];
            cntCB[i+1]=cntCB[i];
        }
        else if(b[i]=='T'){
            cntTB[i+1]=cntTB[i]+1;
            cntAB[i+1]=cntAB[i];
            cntCB[i+1]=cntCB[i];
        }
        else{
            cntTB[i+1]=cntTB[i];
            cntAB[i+1]=cntAB[i];
            cntCB[i+1]=cntCB[i]+1;
        }
    }
}

int get_distance(int x,int y){
    x++;
    y++;
    int noA=cntAA[y]-cntAA[x-1]-cntAB[y]+cntAB[x-1],noT=cntTA[y]-cntTA[x-1]-cntTB[y]+cntTB[x-1],noC=cntCA[y]-cntCA[x-1]-cntCB[y]+cntCB[x+1];
    int res=cnt[y]-cnt[x-1];

    if(noA!=0 or noT!=0 or noC!=0) return -1;
    int rem=res%2;
	return res/2+rem;
}

컴파일 시 표준 에러 (stderr) 메시지

dna.cpp: In function 'void init(std::string, std::string)':
dna.cpp:18:18: warning: comparison of integer expressions of different signedness: 'int' and 'std::__cxx11::basic_string<char>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   18 |     for(int i=0;i<a.size();++i){
      |                 ~^~~~~~~~~
#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...