保龄球。。。。

题目名字

保龄球

题意

这个问题是关于保龄球的游戏策略。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;
} 

 
 

相关推荐

  1. 保龄球。。。。

    2023-12-28 23:16:04       46 阅读
  2. LeetCode——2660. 保龄球游戏的获胜者

    2023-12-28 23:16:04       37 阅读
  3. 2660. 保龄球游戏的获胜者

    2023-12-28 23:16:04       41 阅读
  4. LeetCode 2660. 保龄球游戏的获胜者

    2023-12-28 23:16:04       35 阅读
  5. 保龄球游戏的获胜者(LeetCode日记)

    2023-12-28 23:16:04       24 阅读
  6. LeetCode 2660. 保龄球游戏的获胜者:模拟

    2023-12-28 23:16:04       37 阅读
  7. 算法每日一题:保龄球游戏的获胜者

    2023-12-28 23:16:04       34 阅读
  8. 2023.12.27力扣每日一题——保龄球游戏的获胜者

    2023-12-28 23:16:04       42 阅读

最近更新

  1. 写一个字符设备的驱动步骤

    2023-12-28 23:16:04       0 阅读
  2. Transformer和Bert的原理是什么

    2023-12-28 23:16:04       0 阅读
  3. 使用tkinter 制作工作流ui

    2023-12-28 23:16:04       1 阅读
  4. postman工具介绍

    2023-12-28 23:16:04       1 阅读
  5. vue-路由自动化

    2023-12-28 23:16:04       1 阅读
  6. el-date-picker 扩展

    2023-12-28 23:16:04       1 阅读
  7. Go语言入门之变量、常量、指针以及数据类型

    2023-12-28 23:16:04       1 阅读
  8. Kotlin 处理livedata数据倒灌

    2023-12-28 23:16:04       1 阅读

热门阅读

  1. css设置图片左上角加文字

    2023-12-28 23:16:04       34 阅读
  2. Leetcod面试经典150题刷题记录 —— 栈篇

    2023-12-28 23:16:04       36 阅读
  3. git基本指令

    2023-12-28 23:16:04       37 阅读
  4. TCP与UDP是流式传输协议吗?

    2023-12-28 23:16:04       44 阅读