Submission #1006183

#TimeUsernameProblemLanguageResultExecution timeMemory
1006183HishamAlshehriData Transfer (IOI19_transfer)C++17
0 / 100
6 ms5640 KiB
#include <bits/stdc++.h> using namespace std; vector<int> get_attachment(vector<int> source) { int x = 0, cnt = 0; for (int i = 0; i < source.size(); i++) { if (source[i]) { x ^= (i + 1); cnt++; } } vector<int>ans = source; while (x) { ans.push_back(x % 2); x /= 2; } ans.push_back(cnt % 2); return ans; } vector<int> retrieve(vector<int> data) { int x1 = 0, k = data[data.size() - 1], cnt = 0; int n = (data.size() > 255 ? 255 : 63); for (int i = 0; i < n; i++) { if (data[i]) { cnt++; x1 ^= (i + 1); } } int x2 = 0; for (int i = n; i < data.size() - 1; i++) { x2 += data[i] * (1 << (i - n + 1)); } if (x1 != x2 && cnt % 2 != k) data[x2 ^ x1] ^= 1; return vector<int>(data.begin(), data.begin() + n); }

Compilation message (stderr)

transfer.cpp: In function 'std::vector<int> get_attachment(std::vector<int>)':
transfer.cpp:6:20: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
    6 |  for (int i = 0; i < source.size(); i++)
      |                  ~~^~~~~~~~~~~~~~~
transfer.cpp: In function 'std::vector<int> retrieve(std::vector<int>)':
transfer.cpp:36:20: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   36 |  for (int i = n; i < data.size() - 1; i++)
      |                  ~~^~~~~~~~~~~~~~~~~
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...