描述
小飞最近迷上了一个叫生死狙击的游戏。不过他的技术并不好,假设他的战斗力是•x。不过,他的战斗力是由心情来定的,每天都不同。现有一群(1<=n<=100000)也是玩生死狙击的朋友,他们也有战斗力。小飞想找一些比自己强的人玩,提高自己的战斗力,如:小烨,小祖,小明等。 小飞一共玩了m天,假设其他人的战斗力不变。问:小飞每天可以找到多少比自己强的人。
输入描述
第一行输入一个n,表示有n个朋友;(1<=n<=100000) 第二行输入n个朋友的战斗力;每个朋友战斗力不超过longint;(已有序); 第三行输入一个m,表示有m天;(1<=m<=100000) 接下来m行,表示小飞每天的战斗力;小飞战斗力不超过longint;
输出描述
共m行,每一行小飞每天找到的人数;
小编的话:这么菜也配玩游戏,好好学习吧,骚年~~~
用例输入 1
5
1 1 3 5 5
3
0
2
5
用例输出 1
5
3
0
小编的话:谁让你每天玩的,不玩会死吗???
小编的话:又是二分,直接上模板!!!
#include<bits/stdc++.h>
using namespace std;
long long n,m,k,hp[100005];
int main()
{
scanf("%lld",&n);
for(int i=1;i<=n;i++)scanf("%lld",&hp[i]);
scanf("%lld",&m);//排序,十分重要
for(int i=1;i<=m;i++)//好戏开场了
{
int L=0,R=n+1;
scanf("%lld",&k);
while(L+1<R)
{
int mid=(L+R)/2;
if(k<hp[mid])R=mid;
else L=mid;//经典模板
}
printf("%d\n",n-L);//华丽收场
}
return 0;
}
小编的话:告诉你个秘密,其实小编是一个小学生(六年级),给个评论吧,球球了~~~