結果
| 問題 |
No.253 ロウソクの長さ
|
| コンテスト | |
| ユーザー |
lunnear
|
| 提出日時 | 2019-01-28 05:29:26 |
| 言語 | C++11(廃止可能性あり) (gcc 13.3.0) |
| 結果 |
WA
|
| 実行時間 | - |
| コード長 | 982 bytes |
| コンパイル時間 | 627 ms |
| コンパイル使用メモリ | 54,492 KB |
| 実行使用メモリ | 25,604 KB |
| 平均クエリ数 | 44.50 |
| 最終ジャッジ日時 | 2024-07-16 16:38:54 |
| 合計ジャッジ時間 | 5,050 ms |
|
ジャッジサーバーID (参考情報) |
judge4 / judge3 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| other | AC * 22 WA * 14 |
ソースコード
#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;
int p = 100, pp = -1;
for(; i < 100; i++)
{
a = q(cur);
if(a == 0)
break;
pp = p;
p = cur;
if(a > 0)
{
min = cur + 1;
cur += ((max - min) / 2);
}
else
{
max = cur - 1;
cur -= ((max - min) / 2) - 1;
}
if(cur == (p - 1) && cur == (pp - 2))
cur--;
max--;
min--;
}
std::cout << "! " << cur + i << std::endl;
return 0;
}
lunnear