結果
問題 | No.2753 鳩の巣原理 |
ユーザー | 沙耶花 |
提出日時 | 2024-05-10 21:48:52 |
言語 | C++17(gcc12) (gcc 12.3.0 + boost 1.87.0) |
結果 |
AC
|
実行時間 | 27 ms / 2,000 ms |
コード長 | 668 bytes |
コンパイル時間 | 4,553 ms |
コンパイル使用メモリ | 262,460 KB |
実行使用メモリ | 25,220 KB |
平均クエリ数 | 11.00 |
最終ジャッジ日時 | 2024-12-20 05:03:13 |
合計ジャッジ時間 | 7,245 ms |
ジャッジサーバーID (参考情報) |
judge4 / judge2 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
other | AC * 30 |
ソースコード
#include <stdio.h> #include <bits/stdc++.h> #include <atcoder/all> using namespace atcoder; using mint = modint998244353; using namespace std; #define rep(i,n) for (int i = 0; i < (n); ++i) #define Inf32 1000000001 #define Inf64 1000000000000000001 int main(){ int n; cin>>n; int l = 0,r = n+1; int x = 0,y = n; rep(i,10){ if(l+1==r){ cout<<"? 1"<<endl; continue; } int mid = (l+r)/2; cout<<"? "<<mid<<endl; int ret; cin>>ret; if(mid-l>ret-x){ r = mid; y = ret; } else{ l = mid; x = ret; } //cout<<l<<' '<<r<<' '<<x<<' '<<y<<endl; } cout<<"Yes "<<l<<' '<<r<<endl; return 0; }