Submission #446919

#TimeUsernameProblemLanguageResultExecution timeMemory
446919DeepessonMutating DNA (IOI21_dna)C++17
100 / 100
144 ms10432 KiB
#include <bits/stdc++.h> #define MAX 105000 #include "dna.h" int ps[3][2][MAX]; int dest[3][3][MAX]; void prefix_sum(int* arr,int n){ int count = 0; for(int i=0;i!=n;++i){ count+=*arr; *arr=count; ++arr; } } int get_segment(int*arr,int l,int r) { --l; int res = 0; if(l>=0)res-=arr[l]; res+=arr[r]; return res; } void init(std::string a,std::string b){ std::vector<int> v1,v2; for(auto&x:a){ if(x=='A')v1.push_back(0); else if(x=='T')v1.push_back(1); else v1.push_back(2); } for(auto&x:b){ if(x=='A')v2.push_back(0); else if(x=='T')v2.push_back(1); else v2.push_back(2); } for(int i=0;i!=v1.size();++i){ ps[v1[i]][0][i]++; ps[v2[i]][1][i]++; if(v1[i]!=v2[i]){ dest[v1[i]][v2[i]][i]++; } } for(int i=0;i!=3;++i){ prefix_sum(&ps[i][0][0],MAX-3); prefix_sum(&ps[i][1][0],MAX-3); } for(int i=0;i!=3;++i){ for(int j=0;j!=3;++j){ prefix_sum(&dest[i][j][0],MAX-3); } } } int get_distance(int x,int y){ for(int i=0;i!=3;++i){ if(get_segment(&ps[i][0][0],x,y)!=get_segment(&ps[i][1][0],x,y)){ return -1; } } int tabela[3][3]; for(int i=0;i!=3;++i){ for(int j=0;j!=3;++j){ tabela[i][j]=get_segment(&dest[i][j][0],x,y); } } int custo = 0; for(int i=0;i!=3;++i){ for(int j=0;j!=3;++j){ int min = std::min(tabela[i][j],tabela[j][i]); custo+=min; tabela[i][j]-=min; tabela[j][i]-=min; } } for(int __=0;__!=5;++__) for(int i=0;i!=3;++i){ for(int j=0;j!=3;++j){ for(int k=0;k!=3;++k){ int min = std::min(tabela[i][j],std::min(tabela[j][k],tabela[k][i])); custo+=min*2; tabela[i][j]-=min; tabela[j][k]-=min; tabela[k][i]-=min; } } } return custo; }

Compilation message (stderr)

dna.cpp: In function 'void init(std::string, std::string)':
dna.cpp:34:18: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   34 |     for(int i=0;i!=v1.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...