本篇内容介绍了“如何编写整数二分代码”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!
#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;
}
“如何编写整数二分代码”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注亿速云网站,小编将为大家输出更多高质量的实用文章!
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。