最近大概把有关二分的题目都看了一遍...
嗯..这题是二分查找...二分查找的代码都类似,所以打起来会水很多
但是刚开始打二分还是很容易写挂..所以依旧需要注意
题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。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38 |
#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不会这么傻缺输入的时候逗比了一下
还有自己的代码能力需要加强啦
原文:http://www.cnblogs.com/polebug/p/3659824.html