結果
| 問題 |
No.253 ロウソクの長さ
|
| コンテスト | |
| ユーザー |
lunnear
|
| 提出日時 | 2019-01-28 05:16:33 |
| 言語 | C++11(廃止可能性あり) (gcc 13.3.0) |
| 結果 |
WA
|
| 実行時間 | - |
| コード長 | 827 bytes |
| コンパイル時間 | 495 ms |
| コンパイル使用メモリ | 54,512 KB |
| 実行使用メモリ | 25,940 KB |
| 平均クエリ数 | 58.50 |
| 最終ジャッジ日時 | 2024-07-16 16:38:48 |
| 合計ジャッジ時間 | 7,467 ms |
|
ジャッジサーバーID (参考情報) |
judge5 / judge1 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| other | AC * 13 WA * 23 |
ソースコード
#include <iostream>
int q(int x)
{
int ret;
std::cout << "? " << x << std::endl;
std::cout << std::flush;
std::cin >> ret;
return ret;
}
int main()
{
int a;
a = q(100);
if(a == 0)
{
std::cout << "! 100" << std::endl;
return 0;
}
int min, max, cur, i;
min = 1;
max = (a > 0)? 1000000000:100;
cur = (max - min) / 2;
i = 1;
for(; i < 100; i++)
{
a = q(cur);
if(a == 0)
break;
if(a > 0)
{
min = cur + 1;
cur += (max - min) / 2;
}
else
{
max = cur - 1;
cur -= (max - min) / 2;
}
max--;
min--;
}
std::cout << "! " << cur + i << std::endl;
return 0;
}
lunnear