本篇内容介绍了“如何编写整数二分代码”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!
#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进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。