CF964(div4)补题G1G2

G1. Ruler (easy version)

题意:形式为?1y,如果y<x,则相应y,如果y>=x,则相应y+1

分析:用二分搜索最终值,在二分里输入x

代码:

复制代码
#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
void sol(){
    int l=2,r=1000;
    while(l<r){
        int mid=(l+r)/2;
        cout<<"? 1 "<<mid<<endl;
        int x;cin>>x;
        if(x==mid)l=mid+1;
        else r=mid;
    }
    cout<<"! "<<l<<endl;
}
int main(){
    int t;cin>>t;
    while(t--)sol();
    return 0;
}

G2. Ruler (hard version)

题意:形式为?a b,如果a<b<x,则相应a×b,如果a<x<=b,则相应a×(b+1),如果x<=a<b,则响应(a+1)(b+1)

分析:用三分搜索每次的a和b,在三分里输入x

代码:

复制代码
#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
void sol(){
    int l=1,r=999;
    while(l<r-2){
        int a=(2*l+r)/3;
        int b=(2*r+l)/3;
        cout<<"? "<<a<<" "<<b<<endl;
        int x;cin>>x;
        if(x==(a+1)*(b+1))r=a;
        else if(x==a*b)l=b;
        else{
            l=a;r=b;
        }
    }
    if(r-l==2){
        cout<<"? 1 "<<l+1<<endl;
        int x;cin>>x;
        if(x==l+1)l+=1;
        else r=l+1;
    }
    cout<<"! "<<r<<endl;
}
int main(){
    int t;cin>>t;
    while(t--)sol();
    return 0;
}
相关推荐
十五年专注C++开发1 天前
QtnProperty:一个基于 Qt 框架的第三方高级属性库
开发语言·c++·qt
承渊政道1 天前
【动态规划算法】(子数组系列问题建模与解题思路精讲)
数据结构·c++·学习·算法·leetcode·动态规划·哈希算法
AI进化营-智能译站1 天前
ROS2 C++开发系列04:如何有效输出机器人状态
开发语言·c++·ai·机器人
AI进化营-智能译站1 天前
ROS2 C++开发系列05:机器人启动如何传递命令行参数实战
开发语言·c++·ai·机器人
春蕾夏荷_7282977251 天前
1、c++ acl udp服务器客户端简单实例-客户器端(2)
服务器·c++·udp
落羽的落羽1 天前
【网络】计算机网络世界的基础概念
linux·服务器·网络·c++·人工智能·计算机网络·机器学习
梦想画家1 天前
RAG应用基石:从六种文档切分算法看语义完整性
人工智能·算法·rag
Volunteer Technology1 天前
ES相关度评分算法
大数据·算法·elasticsearch
炽烈小老头1 天前
【每天学习一点算法 2026/04/30】寻找重复数
学习·算法
QuZero1 天前
ReentrantReadWriteLock mechanism
java·后端·算法