这个问题是关于保龄球的游戏策略。DL 想要根据每个位置的瓶子数来选择发球的位置,以便打倒指定数量的瓶子。他想知道针对每次打击,应该选择哪个位置发球
- 定义了一个结构体data,包含两个long long类型的变量
- 定义了一个比较函数cmp,用来在排序时比较
- 定义了一个递归函数pd,用来在排序后的数组中查找特定的数,并返回其对应的位置。
- 然后使用for循环依次输入n个数,并将其存储在结构体数组N中,并且给每个数标记其位置。
- 使用sort函数对数组N进行排序,排序规则是根据h成员变量的大小。
- 输入m,表示有m个数需要查找。
- 使用for循环依次输入m个数,并调用pd函数进行查找,如果找到则输出对应的位置,否则输出0。
- 定义了一个结构体data,包含两个long long类型的变量
- 定义了一个比较函数cmp,用来在排序时比较
- 定义了一个递归函数pd,用来在排序后的数组中查找特定的数,并返回其对应的位置。
- 然后使用for循环依次输入n个数,并将其存储在结构体数组N中,并且给每个数标记其位置。
- 使用sort函数对数组N进行排序,排序规则是根据h成员变量的大小。
- 输入m,表示有m个数需要查找。
- 使用for循环依次输入m个数,并调用pd函数进行查找,如果找到则输出对应的位置,否则输出0。
using namespace std;
long long n,m,a,ans;
struct data
{
long long h,H;
}N[100005];
bool cmp(data x,data y)
{
return x.h<y.h;
}
bool pd(long long A,long long l,long long r)
{
long long mid=(l+r)/2;
if(N[mid].h==A)
{
ans=N[mid].H;
return true;
}
if(l>r)return false;
if(A<=N[mid].h)return pd(A,l,mid-1);
else return pd(A,mid+1,r);
}
int main()
{
cin>>n;
for(long long i=1;i<=n;i++)
{
cin>>N[i].h;
N[i].H=i;
}
sort(N+1,N+1+n,cmp);
cin>>m;
for(long long i=1;i<=m;i++)
{
cin>>a;
if(pd(a,1,n))
{
cout<<ans<<endl;
}
else cout<<0<<endl;
}
return 0;
}