温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

如何编写整数二分代码

发布时间:2021-10-09 16:02:32 来源:亿速云 阅读:94 作者:iii 栏目:编程语言

本篇内容介绍了“如何编写整数二分代码”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

#include <iostream>
#include <cstring>
#include <cstdio>
#include <algorithm>

using namespace std;
//整数二分
//1.划分区间;2.找一个边界点,使得ans在该处;3.缩左补1!
const int N = 100010;
int n,m;
int q[N];

int main(){
    scanf("%d%d",&n,&m);
    //输入待查找数组
    for(int i=0;i<n;i++) scanf("%d",&q[i]);
    //开始查找
    for(int i=0;i<m;i++){
        int x;
        scanf("%d",&x);
        //x是二分区间的左端点,缩右往右
        //确定一个区间
        int l=0,r=n-1;
        //找一个性质
        while(l<r){
            int m=(l+r)>>1; //m=(l+r)/2
            if(q[m]>=x) r=m;
            else l=m+1;
        }
        if(q[r]==x){
            cout<<r<<' ';
            //x是二分区间的右端点,缩左往左还补1
            //区间
            r=n-1;
            //找一个性质
            while(l<r){
                int m=(l+r+1)>>1;
                if(q[m]<=x) l=m;
                else r=m-1;
            }
            cout<<l<<endl;
        }
        else cout<<"-1 -1"<<endl;
    }
    return 0;
}

“如何编写整数二分代码”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注亿速云网站,小编将为大家输出更多高质量的实用文章!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI