제출 #784730

#제출 시각아이디문제언어결과실행 시간메모리
784730Soumya1Xoractive (IZhO19_xoractive)C++17
100 / 100
4 ms456 KiB
#include "interactive.h" #include <bits/stdc++.h> using namespace std; int a0; vector<int> get_values(vector<int> v) { int has = -1; for (int i = 0; i < v.size(); i++) { if (v[i] == 1) has = i; } if (has != -1) v.erase(v.begin() + has); auto v1 = get_pairwise_xor(v); v.push_back(1); auto v2 = get_pairwise_xor(v); vector<int> final; multiset<int> s; for (int i : v2) s.insert(i); for (int i : v1) s.erase(s.find(i)); s.erase(s.find(0)); set<int> ss; for (int i : s) ss.insert(i); for (int i : ss) final.push_back(i ^ a0); if (has != -1) final.push_back(a0); sort(final.begin(), final.end()); return final; } vector<int> guess(int n) { a0 = ask(1); vector<int> ans(n); map<int, int> pos; for (int bit = 0; bit < 7; bit++) { vector<int> p; for (int i = 1; i <= n; i++) { if (i >> bit & 1) p.push_back(i); } if (p.empty()) continue; p = get_values(p); for (int i : p) pos[i] |= (1 << bit); } for (auto [x, y] : pos) { ans[y - 1] = x; } return ans; }

컴파일 시 표준 에러 (stderr) 메시지

Xoractive.cpp: In function 'std::vector<int> get_values(std::vector<int>)':
Xoractive.cpp:7:20: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
    7 |  for (int i = 0; i < v.size(); i++) {
      |                  ~~^~~~~~~~~~
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...