二分交互题总结

简单版

cpp 复制代码
bool query(int x){
    cout<<x<<endl;
    cout.flush();
    string ans;cin>>ans;
    return (ans==">=");
}
void solve()
{
    int n;cin>>n;
    int l=1,r=n;
    if(n==1)return cout<<"! 1"<<endl,void();
    if(n==2){
        if(query(2))return cout<<"! 2"<<endl,void();
        else return cout<<"! 1"<<endl,void();
    }
    int cnt=0;
    while (l<r)
    {
        int mid=(l+r+1)>>2;
        // cout<<l<<' '<<r<<endl;
        if(query(mid)){
            l=mid;
        }else r=mid-1;
        // cout<<l<<' '<<r<<endl;
    }
    cout<<"! "<<l<<endl;
}

进阶

限制四次之内找到 x ′ ∈ [ x 2 , 2 x ] x'\in[{x\over2},2x] x′∈[2x,2x]

思路:

  • x越大 范围越大
  • 打表 找5e9内 [ x 2 , 2 x ] [{x\over2},2x] [2x,2x]的所有区间 每个区间设置一个固定输出值
  • 打完表惊奇地发现区间个数只有16个,四次份 2 4 2^4 24个段,能确定 x ′ x' x′的范围
  • 每次回答问的数y是否>x,0为 y ≤ x y\leq x y≤x
  • 设计问下边界,因为越小区间越短越密集越精确
  • 最后输出区间中间的数
cpp 复制代码
int lo[17],hi[17];
void solve()
{
    int n;cin>>n;
    if(n==1)return cout<<"! 1"<<endl,void();
    int k=2;
    lo[1]=1,hi[1]=4;
    // cout<<lo[1]<<' '<<hi[1]<<endl;
    while (hi[k-1]<n)
    {
        lo[k]=hi[k-1]+1;
        hi[k]=min(lo[k]*4,n);//注意上边界卡在n内 否则会输出超出[1,n]的数
        // cout<<lo[k]<<' '<<hi[k]<<endl;
        k++;
    }
    int l=1,r=k-1;
    while (l<r)
    {
        int mid=(l+r+1)>>1;
        cout<<"? "<<lo[mid]<<endl;
        cout.flush();
        int re;
        cin>>re;
        if(re==1){
            r=mid-1;
        }else{
            l=mid;
        }
    }
    cout<<"! "<<min(lo[l]*2,hi[l])<<endl;
    //一开始输出答案忘了换行 竟然T了 
}
相关推荐
NAGNIP10 小时前
一文搞懂深度学习中的通用逼近定理!
人工智能·算法·面试
颜酱19 小时前
单调栈:从模板到实战
javascript·后端·算法
CoovallyAIHub1 天前
仿生学突破:SILD模型如何让无人机在电力线迷宫中发现“隐形威胁”
深度学习·算法·计算机视觉
CoovallyAIHub1 天前
从春晚机器人到零样本革命:YOLO26-Pose姿态估计实战指南
深度学习·算法·计算机视觉
CoovallyAIHub1 天前
Le-DETR:省80%预训练数据,这个实时检测Transformer刷新SOTA|Georgia Tech & 北交大
深度学习·算法·计算机视觉
CoovallyAIHub1 天前
强化学习凭什么比监督学习更聪明?RL的“聪明”并非来自算法,而是因为它学会了“挑食”
深度学习·算法·计算机视觉
CoovallyAIHub1 天前
YOLO-IOD深度解析:打破实时增量目标检测的三重知识冲突
深度学习·算法·计算机视觉
NAGNIP1 天前
轻松搞懂全连接神经网络结构!
人工智能·算法·面试
NAGNIP1 天前
一文搞懂激活函数!
算法·面试
董董灿是个攻城狮1 天前
AI 视觉连载7:传统 CV 之高斯滤波实战
算法