pearl(二分查找,stl)

最近大概把有关二分的题目都看了一遍...

嗯..这题是二分查找...二分查找的代码都类似,所以打起来会水很多

但是刚开始打二分还是很容易写挂..所以依旧需要注意

题2 天堂的珍珠

【题目描述】

我有很多很多(n条)用魔法合成的珍珠项链……(其实神仙比凡人更爱美),每天起来我都要从中挑一条戴上……挑哪条很有讲究,如果比情敌**的难看,那么就会被**(-_-),如果比天后Hera的好看,那么就完蛋了(-_-)。所以我希望你能帮帮我,解决这个令人头疼的问题——每天帮我算算,那天我能戴的项链有多少条。

【输入文件】(pearl.in):

第一行为正整数n(项链总条数)。

第二行有n个整数(代表每条项链晶的好看程度Xi,0<=Xi<=maxlongint。)

第三行为正整数m,表示总天数(也就是总询问次数)。

以下m行,每行两个整数Ai,Bi(1<=Ai,Bi<=maxlongint),询问好看程度在Ai到Bi之间的项链条数(含等于Ai或Bi的,Ai与Bi大小关系不确定)。

【输出文件】(pearl.out):

输出m行,对于每次询问输出一行,从Ai到Bi(含Ai,Bi)好看程度在Ai到Bi之间的项链条数。

【输入样例1】:

7

8 2 3 5 6 7 7

6

1 5

8 6

1 10

5 5

4 4

7 8

【输出样例1】:

3

4

7

1

0

3

【数据规模】

对于25%数据,有m,n<=1000。

对于100%数据,有m,n<=100000
pearl
#include<cstdio>

#include<algorithm>

using namespace std;

int a[100001],b[100001],s=0,p=0,n,mid;

int main(){

	int i,j,t,m,x,y;

	freopen("pearl.in","r",stdin);freopen("pearl.out","w",stdout);

	

	scanf("%d",&n);

	for (int i=0;i<n;i++) scanf("%d",&a[i]);

	sort(a,a+n);

	scanf("%d",&m);

	for (int i=0;i<m;i++){

		int r=n-1,l=0;

		scanf("%d%d",&x,&y);

		if (x>y) {t=x;x=y;y=t;}

		if (x<a[0]) x=a[0];if (y>a[n-1]) y=a[n-1];

	    while(l!=r){

	    	mid=(l+r)>>1;

	    	if(x>a[mid])l=l+1;

	    	   else     r=mid;

	    }

	    if(a[l]<x) l=l+1;

	    s=l;

	    r=n-1,l=0;

	    while(l!=r){

	    	mid=(l+r)>>1;

	    	if(y>=a[mid])l=l+1;

	    	   else     r=mid;

	    }

	    if(a[l]>y)l=l-1;

	    p=l;

        if(s>p)b[i]=0;

          else b[i]=p-s+1;

        }

     for(i=0;i<m;i++) printf("%d\n",b[i]);

    return 0;

}

  表示调用sort简直爽

     以及自己年轻了一下,以为cena不会这么傻缺输入的时候逗比了一下

     还有自己的代码能力需要加强啦


 

     哦。。之后看到了这题调用stl的方法...这里mark一下

#include<cstdio>

#include<algorithm>

#include<cstring>

using namespace std;

int v[100001],w[100001];

int main(){

	int n,m,a,b;

	freopen("pearl.in","r",stdin);freopen("pearl.out","w",stdout);

	scanf("%d%d",&n,&m);

	for(int i=0;i<n;i++) scanf("%d",&v[i]);

	sort(v,v+n);

	for(int i=0;i<m;i++){

		scanf("%d%d",&a,&b);

		w[i]=upper_bound(v,v+n,b)-lower_bound(v,v+n,a);

	}

	for (int i=0;i<m;i++) printf("%d\n",w[i]);

	fclose(stdin);fclose(stdout);

	return 0;

}

  

你可能感兴趣的:(二分查找)