結果
問題 | No.2124 Guess the Permutation |
ユーザー |
|
提出日時 | 2022-12-11 20:49:20 |
言語 | C++17 (gcc 13.3.0 + boost 1.87.0) |
結果 |
AC
|
実行時間 | 59 ms / 2,000 ms |
コード長 | 1,055 bytes |
コンパイル時間 | 676 ms |
コンパイル使用メモリ | 71,508 KB |
最終ジャッジ日時 | 2025-02-09 09:46:09 |
ジャッジサーバーID (参考情報) |
judge3 / judge4 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 1 |
other | AC * 9 |
ソースコード
#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;}