EOJ(排序)——2890. 询问队员身高

2890. 询问队员身高

ECNU 篮球队教练陈老师选拔了一批篮球队员。对于篮球运动,队员身高是重要因素之一,陈老师的记忆力不好,他经常会向助理教练询问身高第 i 高的人是谁。助理教练不胜其烦,想请你帮忙写个程序回答陈老师的询问。
备注:每个队员的身高都各不相同。

输入

第一行是一个整数 t,表示测试数据组数。
对于每组测试数据:
第一行是两个整数 n,m (1≤n≤50,1≤m≤50),n 表示队员的人数,m 表示询问的次数
第二行有 n 个整数,a1,a2,a3,…,an,依次为第 1 个到第 n 个队员的身高 (1≤i≤n,170≤ai≤230)。
第三行有 m 个整数,b1,b2,b3,…,bm,bj 表示教练陈老师的第 j 个询问,询问身高第 bj 高的队员编号 (1≤j≤m,1≤bj≤n)

输出

每组测试数据输出一行,每行输出 m 个整数,依次表示所求队员的编号。两个整数之间用一个空格分开,每行的最后有一个换行符。
样例

input

2
3 1
228 205 190
3
5 3
223 179 217 195 193
3 4 5

output

3
4 5 2

题目大意

给出队员身高信息,做出查询。

题目解析:

结构体排序。

具体代码:

#include<iostream>
#include<algorithm>
using namespace std;
struct node{
	int id;
	int h;
}A[100];
bool cmp(node x,node y){
	return x.h>y.h; 
}
int main()
{
    int T,n,m;
    cin>>T;
    while(T--){
    	cin>>n>>m;
   		for(int i=1;i<=n;i++){
   			cin>>A[i].h;
   			A[i].id=i;
		}
    	sort(A+1,A+n+1,cmp);
    	while(m--){
    		int k;
    		cin>>k;
    		cout<<A[k].id<<" ";
		}
		cout<<endl;
	}
    return 0;
}
全部评论

相关推荐

Twilight_m...:表格简历有点难绷。说说个人看法: 1.个人基本情况里好多无意义信息,什么婚姻状况、健康状况、兴趣爱好、户口所在地、身份证号码、邮政编码,不知道的以为你填什么申请表呢。 2.校内实践个人认为对找工作几乎没帮助,建议换成和测开有关的项目,实在没得写留着也行。 3.工作经历完全看不出来是干什么的,起码看着和计算机没啥关系,建议加强描述,写点你在工作期间的实际产出、解决了什么问题。 4.个人简述大而空,看着像AI生成,感觉问题最大。“Python,C,C++成为我打造高效稳定服务的得力工具”、“我渴望凭借自身技术知识与创新能力,推动人工智能技术的应用发展,助力社会实现智能化转型”有种小学作文的美感。而且你确定你个人简述里写的你都会嘛?你AI这块写的什么“深入研究”,发几篇顶会的硕博生都不一定敢这么写。而且你AI这块的能力和软测也完全无关啊。个人简述建议写你对哪些技术栈、哪些语言、哪些生产工具的掌握,写的有条理些,而且最好是和测开强相关的。
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务