Submission #104584

#TimeUsernameProblemLanguageResultExecution timeMemory
104584dailiGenetics (BOI18_genetics)C++14
46 / 100
2085 ms4676 KiB
#include <bits/stdc++.h> using namespace std; int diff(string a, string b) { int cnt = 0; for (int i = 0; i < a.size() ; i++) { if (a[i] != b[i]) { cnt++; } } return cnt; } void Task1(int n, int m ,int k) { vector<string> all; for (int i =0; i <n ; i++) { string x; cin >> x; all.push_back(x); } for (int i = 0; i < n; i++) { bool flag = true; for (int j = 0; j < n; j++) { if (i == j) { continue; } if (diff(all[i], all[j]) != k) { flag = false; break; } } if (flag) { cout << i+1 << "\n"; return; } } } void TaskBC(int n, const int m, int k) { vector<bitset<4101> > all; for (int i = 0; i < n; i++) { bitset<4101> bit; string x; cin >> x; for (int j = 0; j < m; j++) { if (x[j] == 'A') { bit[j] = 1; } } all.push_back(bit); } for (int i = 0; i < n; i++) { bool flag = true; for (int j = 0; j < n; j++) { if (i == j) { continue; } bitset<4101> xr = all[i] ^ all[j]; if (xr.count() != k) { flag = false; break; } } if (flag) { cout << i+1 << "\n"; return; } } } signed main() { ios_base::sync_with_stdio(false); cin.tie(0); int n, m, k; cin >> n >> m >> k; if (n <= 100 && m <= 100) { Task1(n, m, k); } else { TaskBC(n, m, k); } }

Compilation message (stderr)

genetics.cpp: In function 'int diff(std::__cxx11::string, std::__cxx11::string)':
genetics.cpp:8:23: warning: comparison between signed and unsigned integer expressions [-Wsign-compare]
     for (int i = 0; i < a.size() ; i++)
                     ~~^~~~~~~~~~
genetics.cpp: In function 'void TaskBC(int, int, int)':
genetics.cpp:83:28: warning: comparison between signed and unsigned integer expressions [-Wsign-compare]
             if (xr.count() != k)
                 ~~~~~~~~~~~^~~~
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...