Submission #1006186

#TimeUsernameProblemLanguageResultExecution timeMemory
1006186HishamAlshehriData Transfer (IOI19_transfer)C++17
0 / 100
5 ms5652 KiB
#include <bits/stdc++.h> using namespace std; vector<int> get_attachment(vector<int> source) { int x = 0, cnt = 0; for (int i = 1; i <= source.size(); i++) { if (source[i - 1]) { x ^= i; 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 = 1; i <= n; i++) { if (data[i - 1]) { cnt++; x1 ^= i; } } int x2 = 0; for (int i = n + 1; i <= data.size() - 1; i++) { x2 += data[i - 1] * (1 << (i - n)); } if (x1 != x2 && cnt % 2 != k) data[(x2 ^ x1) - 1] ^= 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 = 1; i <= source.size(); i++)
      |                  ~~^~~~~~~~~~~~~~~~
transfer.cpp: In function 'std::vector<int> retrieve(std::vector<int>)':
transfer.cpp:36:24: 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 + 1; i <= data.size() - 1; i++)
      |                      ~~^~~~~~~~~~~~~~~~~~
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...