結果

問題 No.253 ロウソクの長さ
ユーザー tanimani364
提出日時 2019-12-05 17:30:10
言語 C++17(1z)
(gcc 9.2.0)
結果
WA  
実行時間 -
コード長 1,507 Byte
コンパイル時間 1,088 ms
使用メモリ 17,220 KB
平均クエリ数 54.36
最終ジャッジ日時 2020-01-13 18:20:33

テストケース

テストケース表示
入力 結果 実行時間
使用メモリ
system_test1.txt AC 16 ms
16,660 KB
test1.txt AC 12 ms
16,612 KB
test2.txt AC 12 ms
17,180 KB
test3.txt AC 12 ms
17,188 KB
test4.txt AC 12 ms
16,672 KB
test5.txt AC 12 ms
17,072 KB
test6.txt AC 16 ms
16,764 KB
test7.txt AC 16 ms
16,936 KB
test8.txt AC 12 ms
17,148 KB
test9.txt AC 12 ms
16,948 KB
test10.txt AC 12 ms
16,752 KB
test11.txt AC 12 ms
17,200 KB
test12.txt AC 16 ms
17,060 KB
test13.txt AC 16 ms
16,764 KB
test14.txt AC 12 ms
16,648 KB
test15.txt AC 12 ms
17,220 KB
test16.txt WA -
test17.txt AC 12 ms
17,200 KB
test18.txt AC 12 ms
17,060 KB
test19.txt WA -
test20.txt AC 16 ms
17,200 KB
test21.txt AC 12 ms
16,936 KB
test22.txt AC 12 ms
16,656 KB
test23.txt AC 12 ms
17,168 KB
test24.txt AC 12 ms
16,936 KB
test25.txt AC 16 ms
16,660 KB
test26.txt AC 12 ms
17,136 KB
test27.txt AC 12 ms
16,724 KB
test28.txt AC 16 ms
17,220 KB
test29.txt AC 16 ms
16,644 KB
test30.txt AC 16 ms
16,656 KB
test31.txt AC 16 ms
17,200 KB
test32.txt AC 16 ms
17,148 KB
test33.txt AC 16 ms
17,148 KB
test34.txt AC 16 ms
16,648 KB
test35.txt AC 16 ms
17,136 KB
テストケース一括ダウンロード

ソースコード

diff #
#include<iostream>
#include<string>
#include<vector>
#include<algorithm>
#include<map>
#include<set>
#include<cstdio>
#include<cmath>
#include<numeric>
#include<queue>
#include<stack>
#include<cstring>
#include<limits>
#include<functional>
#include<unordered_set>
#include<iomanip>
#include<cassert>
#include<regex>
#define rep(i,a) for(int i=(int)0;i<(int)a;++i)
#define pb push_back
#define eb emplace_back
using ll=long long;
constexpr ll mod = 1e9 + 7;
constexpr ll INF = 1LL << 50;
 
template<class T> inline bool chmin(T& a, T b) {
    if (a > b) {
        a = b;
        return true;
    }
    return false;
}
template<class T> inline bool chmax(T& a, T b) {
    if (a < b) {
        a = b;
        return true;
    }
    return false;
}
using namespace std;

int C(int mid){
    cout<<"? "<<mid<<endl;
    int res;
    cin>>res;
    return res;
}
void solve(){
    int l,r,mid;
    int cnt=0;
    int x;
    rep(i,50){
        mid=i+10;
        x=C(mid);
        if(x==-1){
            cout<<mid+cnt-1<<endl;
            return;
        }
        else if(x==0){
            cout<<"! "<<mid+cnt<<endl;
            return;
        }
        ++cnt;
    }
    l=109,r=1e9+1;
    rep(i,50){
        mid=(l+r)/2;
        x=C(mid-cnt);
        if(x==-1)r=mid;
        else if(x==1)l=mid;
        else {
            cout<<"! "<<mid<<endl;
            return ;
        }
        ++cnt;
    }
}
 
int main(){
	ios::sync_with_stdio(false);
    cin.tie(0);
	cout<<fixed<<setprecision(15);
	solve();
	return 0;
}
0