結果

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

テストケース

テストケース表示
入力 結果 実行時間
使用メモリ
system_test1.txt AC 16 ms
16,740 KB
test1.txt AC 12 ms
16,652 KB
test2.txt AC 12 ms
17,160 KB
test3.txt AC 12 ms
16,688 KB
test4.txt AC 12 ms
16,856 KB
test5.txt AC 12 ms
17,128 KB
test6.txt AC 12 ms
17,120 KB
test7.txt AC 12 ms
16,688 KB
test8.txt AC 16 ms
17,120 KB
test9.txt AC 12 ms
17,116 KB
test10.txt AC 16 ms
16,752 KB
test11.txt AC 16 ms
17,052 KB
test12.txt AC 16 ms
17,128 KB
test13.txt AC 12 ms
17,120 KB
test14.txt AC 12 ms
17,120 KB
test15.txt AC 12 ms
17,036 KB
test16.txt WA -
test17.txt AC 16 ms
16,680 KB
test18.txt AC 16 ms
16,764 KB
test19.txt WA -
test20.txt AC 12 ms
16,844 KB
test21.txt AC 12 ms
16,664 KB
test22.txt AC 12 ms
16,856 KB
test23.txt AC 12 ms
16,596 KB
test24.txt AC 12 ms
16,764 KB
test25.txt AC 12 ms
17,128 KB
test26.txt AC 12 ms
17,160 KB
test27.txt AC 12 ms
17,064 KB
test28.txt AC 12 ms
16,764 KB
test29.txt AC 12 ms
16,728 KB
test30.txt AC 16 ms
16,652 KB
test31.txt AC 12 ms
16,656 KB
test32.txt AC 12 ms
16,864 KB
test33.txt AC 16 ms
17,028 KB
test34.txt AC 12 ms
16,868 KB
test35.txt AC 12 ms
16,688 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<<"\n";
            return;
        }
        else if(x==0){
            cout<<"! "<<mid+cnt<<"\n";
            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