#include <stdio.h>
#include <stdlib.h>
#include <iostream>
#include <random>
#include <algorithm>
#include <cassert>
int q;
int query(int x, int y, int z) {
q--;
printf("? %d %d %d\n", x, y, z);
fflush(stdout);
int ans = -1;
(void)scanf("%d", &ans);
if (ans == -1) exit(0);
return ans;
}
__attribute__((noreturn))
void guess(int x, int y, int z) {
printf("! %d %d %d\n", x, y, z);
exit(0);
}
std::mt19937 rng(123);
struct Max {
int x, y, z, value;
bool operator < (const Max &other) const {
return value < other.value;
};
};
const int dx[6] = {+1, -1, 0, 0, 0, 0};
const int dy[6] = {0, 0, +1, -1, 0, 0};
const int dz[6] = {0, 0, 0, 0, +1, -1};
int main() {
int n, m, k;
std::cin >> n >> m >> k >> q;
Max maxi;
maxi.x = maxi.y = maxi.z = 1;
maxi.value = query(1, 1, 1);
int steps = q / 2;
for (int i = 0; i < steps; i++) {
int x = rng() % n + 1, y = rng() % m + 1, z = rng() % k + 1;
Max nw;
nw.x = rng() % n + 1;
nw.y = rng() % m + 1;
nw.z = rng() % k + 1;
nw.value = query(nw.x, nw.y, nw.z);
maxi = std::max(maxi, nw);
}
while (q > 0) {
for (int i = 0; i < 6 && q > 0; i++) {
Max nw = maxi;
nw.x += dx[i];
nw.y += dy[i];
nw.z += dz[i];
if (1 <= nw.x && nw.x <= n && 1 <= nw.y && nw.y <= m && 1 <= nw.z && nw.z <= k) {
nw.value = query(nw.x, nw.y, nw.z);
if (maxi < nw) {
maxi = nw;
break;
}
}
}
}
std::cout << "! " << maxi.x << ' ' << maxi.y << ' ' << maxi.z << '\n';
return 0;
}
컴파일 시 표준 에러 (stderr) 메시지
worm.cpp: In function 'int query(int, int, int)':
worm.cpp:15:20: warning: ignoring return value of 'int scanf(const char*, ...)' declared with attribute 'warn_unused_result' [-Wunused-result]
15 | (void)scanf("%d", &ans);
| ~~~~~^~~~~~~~~~~~
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |