結果
| 問題 | No.3501 Digit Products 2 |
| コンテスト | |
| ユーザー |
|
| 提出日時 | 2026-04-18 22:51:39 |
| 言語 | C++23 (gcc 15.2.0 + boost 1.89.0) |
| 結果 |
WA
|
| 実行時間 | - |
| コード長 | 1,436 bytes |
| 記録 | |
| コンパイル時間 | 1,227 ms |
| コンパイル使用メモリ | 179,504 KB |
| 実行使用メモリ | 30,320 KB |
| 平均クエリ数 | 10.89 |
| 最終ジャッジ日時 | 2026-04-18 22:51:56 |
| 合計ジャッジ時間 | 8,490 ms |
|
ジャッジサーバーID (参考情報) |
judge3_1 / judge2_1 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | RE * 1 |
| other | AC * 35 WA * 9 RE * 28 |
コンパイルメッセージ
main.cpp: In function 'int sqrt(ll)':
main.cpp:12:1: warning: control reaches end of non-void function [-Wreturn-type]
12 | }
| ^
ソースコード
#include <string>
#include <iostream>
#include <vector>
#include <stack>
using namespace std;
using ll = long long;
#define rep(i, n) for(int i=0; i<n; ++i)
int sqrt(ll x) {
for(int i=1; i<10; i++) if(x == i * i) return i;
}
int main() {
ll n;
cin >> n;
if(n == 2) {
cout << "? 0 1" << endl;
ll ret;
cin >> ret;
if(ret == 1) {
cout << "! 11" << endl;
} else if(ret == 25) {
cout << "! 55" << endl;
} else if(ret == 49) {
cout << "! 77" << endl;
} else if(ret == 64) {
cout << "! 88" << endl;
} else if(ret == 81) {
cout << "! 99" << endl;
} else {
cout << "! -1" << endl;
return 0;
}
} else {
vector<ll> res(10, n);
vector<ll> non_zero;
rep(i, n-1){
cout << "? " << i << " " << n-1 << endl;
cin >> res[i];
if(res[i] != 0) non_zero.emplace_back(i);
}
if(non_zero.size() < 2) {
cout << "! -1" << endl;
return 1;
}
cout << "? " << non_zero[0] << " " << non_zero[1] << endl;
ll res01;
cin >> res01;
res[n-1] = res[non_zero[0]] * res[non_zero[1]] / res01;
ll a_back = sqrt(res[n-1]);
cout << "! ";
rep(i, n) {
cout << res[n-1-i] / a_back;
}
cout << endl;
}
}