保龄球。。。。

题目名字

保龄球

题意

这个问题是关于保龄球的游戏策略。DL 想要根据每个位置的瓶子数来选择发球的位置,以便打倒指定数量的瓶子。他想知道针对每次打击,应该选择哪个位置发球

思路

  1. 定义了一个结构体data,包含两个long long类型的变量
  2. 定义了一个比较函数cmp,用来在排序时比较
  3. 定义了一个递归函数pd,用来在排序后的数组中查找特定的数,并返回其对应的位置。
  4. 然后使用for循环依次输入n个数,并将其存储在结构体数组N中,并且给每个数标记其位置。
  5. 使用sort函数对数组N进行排序,排序规则是根据h成员变量的大小。
  6. 输入m,表示有m个数需要查找。
  7. 使用for循环依次输入m个数,并调用pd函数进行查找,如果找到则输出对应的位置,否则输出0。

算法一:结构体排序+二分查找

实现步骤
  1. 定义了一个结构体data,包含两个long long类型的变量
  2. 定义了一个比较函数cmp,用来在排序时比较
  3. 定义了一个递归函数pd,用来在排序后的数组中查找特定的数,并返回其对应的位置。
  4. 然后使用for循环依次输入n个数,并将其存储在结构体数组N中,并且给每个数标记其位置。
  5. 使用sort函数对数组N进行排序,排序规则是根据h成员变量的大小。
  6. 输入m,表示有m个数需要查找。
  7. 使用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;
} 

 
 

你可能感兴趣的:(算法,数据结构)