Submission #829713

#TimeUsernameProblemLanguageResultExecution timeMemory
829713haxormanData Transfer (IOI19_transfer)C++14
100 / 100
163 ms2516 KiB
#include "transfer.h" #include <bits/stdc++.h> using namespace std; vector<int> get_attachment(vector<int> source) { int end = 0; vector<int> res; for (int j = 0; (1 << j) < source.size(); ++j) { int val = 0; for (int i = 0; i < source.size(); ++i) { if ((i + 1) & (1 << j)) { val ^= source[i]; } } res.push_back(val); end ^= val; } res.push_back(end); return res; } vector<int> retrieve(vector<int> data) { bool smol = (data.size() == 70); vector<int> source; for (int i = 0; i < data.size() - (smol ? 7 : 9); ++i) { source.push_back(data[i]); } int end = 0; vector<int> lst; for (int i = data.size() - (smol ? 7 : 9); i < data.size() - 1; ++i) { lst.push_back(data[i]); end ^= data[i]; } if (end != data.back()) { return source; } int bad = 0, tot = 0; for (int j = 0; (1 << j) < source.size(); ++j) { int val = 0; for (int i = 0; i < source.size(); ++i) { if ((i + 1) & (1 << j)) { val ^= source[i]; } } if (val != lst[j]) { bad += (1 << j); } } if (bad) { source[bad - 1] ^= 1; } return source; }

Compilation message (stderr)

transfer.cpp: In function 'std::vector<int> get_attachment(std::vector<int>)':
transfer.cpp:8:30: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
    8 |     for (int j = 0; (1 << j) < source.size(); ++j) {
      |                     ~~~~~~~~~^~~~~~~~~~~~~~~
transfer.cpp:10:27: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   10 |         for (int i = 0; i < source.size(); ++i) {
      |                         ~~^~~~~~~~~~~~~~~
transfer.cpp: In function 'std::vector<int> retrieve(std::vector<int>)':
transfer.cpp:26:23: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   26 |     for (int i = 0; i < data.size() - (smol ? 7 : 9); ++i) {
      |                     ~~^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
transfer.cpp:32:50: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   32 |     for (int i = data.size() - (smol ? 7 : 9); i < data.size() - 1; ++i) {
      |                                                ~~^~~~~~~~~~~~~~~~~
transfer.cpp:42:30: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   42 |     for (int j = 0; (1 << j) < source.size(); ++j) {
      |                     ~~~~~~~~~^~~~~~~~~~~~~~~
transfer.cpp:44:27: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   44 |         for (int i = 0; i < source.size(); ++i) {
      |                         ~~^~~~~~~~~~~~~~~
transfer.cpp:41:18: warning: unused variable 'tot' [-Wunused-variable]
   41 |     int bad = 0, tot = 0;
      |                  ^~~
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...