結果
問題 | No.2124 Guess the Permutation |
ユーザー | みここ |
提出日時 | 2022-12-11 20:49:20 |
言語 | C++17 (gcc 13.3.0 + boost 1.87.0) |
結果 |
AC
|
実行時間 | 48 ms / 2,000 ms |
コード長 | 1,055 bytes |
コンパイル時間 | 686 ms |
コンパイル使用メモリ | 73,364 KB |
実行使用メモリ | 24,964 KB |
平均クエリ数 | 374.60 |
最終ジャッジ日時 | 2024-10-15 16:25:38 |
合計ジャッジ時間 | 1,812 ms |
ジャッジサーバーID (参考情報) |
judge1 / judge4 |
(要ログイン)
テストケース
テストケース表示入力 | 結果 | 実行時間 実行使用メモリ |
---|---|---|
testcase_00 | AC | 23 ms
24,812 KB |
testcase_01 | AC | 21 ms
24,964 KB |
testcase_02 | AC | 20 ms
24,964 KB |
testcase_03 | AC | 21 ms
24,824 KB |
testcase_04 | AC | 23 ms
24,836 KB |
testcase_05 | AC | 22 ms
24,580 KB |
testcase_06 | AC | 36 ms
24,836 KB |
testcase_07 | AC | 46 ms
24,836 KB |
testcase_08 | AC | 48 ms
24,832 KB |
testcase_09 | AC | 48 ms
24,836 KB |
ソースコード
#include <algorithm> #include <iostream> using namespace std; int main() { int n; cin >> n; cout << "?" << " " << 1 << " " << 2 << endl; int s; cin >> s; cout << "?" << " " << 2 << " " << 3 << endl; int t; cin >> t; if (n == 3) { int p[3] = {1, 2, 3}; do { if (p[0] + p[1] == s && p[1] + p[2] == t) { cout << "!" << " " << p[0] << " " << p[1] << " " << p[2] << endl; return 0; } } while (next_permutation(p, p + 3)); } cout << "?" << " " << 1 << " " << 3 << endl; int u; cin >> u; int p[1005]; p[0] = u - t; p[1] = s + t - u; p[2] = u - s; for (int i = 3; i < n - 1; i++) { int v; cout << "?" << " " << 1 << " " << i + 1 << endl; cin >> v; p[i] = v - u; u = v; } p[n - 1] = n * (n + 1) / 2 - u; cout << "!"; for (int i = 0; i < n; i++) { cout << " " << p[i]; } cout << endl; }