最近大概把有关二分的题目都看了一遍...
嗯..这题是二分查找...二分查找的代码都类似,所以打起来会水很多
但是刚开始打二分还是很容易写挂..所以依旧需要注意
题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。
#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; }