首页 > 代码库 > 保龄球

保龄球

https://www.luogu.org/problem/show?pid=1918

题目描述

DL 算缘分算得很烦闷,所以常常到体育馆去打保龄球解闷。因为他保龄球已经打了几十年了,所以技术上不成问题,于是他就想玩点新花招。

DL 的视力真的很不错,竟然能够数清楚在他前方十米左右每个位置的瓶子的数量。他突然发现这是一个炫耀自己好视力的借口——他看清远方瓶子的个数后从某个位置发球,这样就能打倒一定数量的瓶子。

1 OOO

2 OOOO

3 O 4 OO

如上图,每个“O”代表一个瓶子。如果 DL 想要打倒 3 个瓶子就在 1 位置发球,想要打倒 4 个瓶子就在 2 位置发球。

现在他想要打倒 m 个瓶子。他告诉你每个位置的瓶子数,请你给他一个发球位置。

输入输出格式

输入格式:

 

输入文件名为 bowling.in。

第一行包含一个正整数 n,表示位置数。

第二行包含 n 个正整数,第 i 个数。表示第 i 个位置的瓶子数,保证各个位置的瓶子数不同。

第三行包含一个正整数 Q,表示 DL 发球的次数。

第四行至文件末尾,每行包含一个正整数 m,表示 DL 需要打倒 m 个瓶子。

 

输出格式:

 

输出文件名为 bowling.out。

共 Q 行。每行包含一个整数,第 i 行的整数表示 DL 第 i 次的发球位置。若无解,则输出 0。

 

输入输出样例

输入样例#1:
51 2 4 3 5247
输出样例#1:
30

说明

【数据范围】

对于 50%的数据,1 ≤ n,Q ≤ 1000,1 ≤ai,M ≤ 10^5

对于 1000%的数据,1 ≤ n,Q ≤ 100000,1 ≤ai,M ≤ 10^9

技术分享
 1 #include <algorithm> 2 #include <iostream> 3 #include <cstdio> 4 #define maxn 100015 5 using namespace std; 6  7 int n,m; 8 int b,l,r,midd; 9 bool judge;10 struct node11 {12     int id,x;13 }a[maxn];14 15 bool cmp(node aa,node bb)16 {17     return aa.x<bb.x;18 }19 20 int main()21 {22     cin>>n;23     for(int i=1;i<=n;i++)24     {25         cin>>a[i].x;26         a[i].id=i;27     }28     sort(a+1,a+n+1,cmp);29     cin>>m;30     for(int i=1;i<=m;i++)31     {32         cin>>b;33         l=1;r=n;judge=false;34         while(l<=r)35         {36             midd=(l+r)/2;37             if(b<a[midd].x)38             {39                 r=midd-1;40                 continue;41             }42             if(b>a[midd].x)43             {44                 l=midd+1;45                 continue;46             }47             if(b==a[midd].x)48             {49                 judge=true;50                 break;    51             }52             53         }54         if(judge)55         {56             cout<<a[midd].id<<endl;57             continue;58         }59         else60             cout<<0<<endl;61     }62     return 0;63 }
二分查找+快排

 

保龄球