先看二分查找的一般写法
#include<stdio.h> #include<math.h> #include<string.h> #include<stdlib.h> #include<algorithm> #include<vector> using namespace std; #define N 100005 #define ll __int64 int n,a[N]; int findd(int x) { int l=0,r=n-1; while(l<=r) { int mid=(l+r)>>1; if(a[mid]==x) return mid; if(a[mid]>x) r=mid-1; else l=mid+1; } return -1; //没有找到 } int main() { int i,m,x,t; while(~scanf("%d",&n)) { for(i=0;i<n;i++) { scanf("%d",&a[i]); } sort(a,a+n); scanf("%d",&m); while(m--) { scanf("%d",&x); t=findd(x); printf("%d\n",t); } } return 0; }
一般的二分查找只能找到目标值,但是当目标值重复出现时返回的下标就不确定,下面的写法可以返回最先出现的目标值的下标。当目标值未出现时,返回比目标值大的那个元素的下标或者返回边界值n;
#include<stdio.h> #include<math.h> #include<string.h> #include<stdlib.h> #include<algorithm> #include<vector> using namespace std; #define N 100005 #define ll __int64 int n,a[N]; int findd(int x) { int l=0,r=n-1; while(l<=r) { int mid=(l+r)>>1; if(a[mid]>=x) r=mid-1; else l=mid+1; /*if(a[mid]<x) //这种写法也上面同样效果 l=mid+1; else r=mid-1;*/ } return l; //返回目标值的下标,若有多个值相同,返回最先出现的下标。 } int main() { int i,m,x,t; while(~scanf("%d",&n)) { for(i=0;i<n;i++) { scanf("%d",&a[i]); } sort(a,a+n); scanf("%d",&m); while(m--) { scanf("%d",&x); t=findd(x); printf("%d\n",t); } } return 0; }
原文:http://blog.csdn.net/u011721440/article/details/42026829