제출 #729122

#제출 시각아이디문제언어결과실행 시간메모리
729122vjudge1DNA 돌연변이 (IOI21_dna)C++17
56 / 100
41 ms5740 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{ cntCA[i+1]=cntCA[i]+1; cntTA[i+1]=cntTA[i]; cntAA[i+1]=cntAA[i]; } 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{ cntCB[i+1]=cntCB[i]+1; cntTB[i+1]=cntTB[i]; cntAB[i+1]=cntAB[i]; } } } 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...