zoukankan      html  css  js  c++  java
  • 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
    ",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
    ",w[i]);
    	fclose(stdin);fclose(stdout);
    	return 0;
    }
    

      

  • 相关阅读:
    MySQL事务
    MySQL索引
    MySQL基础
    设计模式之单例模式
    设计模式之适配器模式
    zookeeper学习记录第二篇-----安装、配置、启动
    Scrapy 安装
    shiro
    python 爬虫简介以及使用方法
    linux VMware使用
  • 原文地址:https://www.cnblogs.com/polebug/p/3659824.html
Copyright © 2011-2022 走看看