当前位置: 首页 > 面试经验 >

2024年华为OD机试真题-寻找身高相近的小朋友

优质
小牛编辑
91浏览
2024-07-13

2024年华为OD机试真题-寻找身高相近的小朋友

华为OD机试真题-寻找身高相近的小朋友-2024年OD统一考试(D卷)

题目描述:

小明今年升学到小学一年级,来到新班级后发现其他小朋友们身高参差不齐,然后就想基于各小朋友和自己的身高差对他们进行排序,请帮他实现排序。

输入描述:

第一行为正整数H和N,0<H<200,为小明的身高,0<N<50,为新班级其他小朋友个数。

第二行为N个正整数H1-HN,分别是其他小朋友的身高,取值范围0<Hi<200(1<=i<=N),且N个正整数各不相同。

输出描述:

输出排序结果,各正整数以空格分割。和小明身高差绝对值最小的小朋友排在前面,和小明身高差绝对值最大的小朋友排在最后,如果两个小朋友和小明身高差一样,则个子较小的小朋友排在前面。

补充说明:

示例1

输入:

100 10

95 96 97 98 99 101 102 103 104 105

输出:

99 101 98 102 97 103 96 104 95 105

说明:

小明身高100,班级学生10个,身高分别为95 96 97 98 99 101 102 103 104 105,按身高差排序后结果为:99 101 98 102 97 103 96 104 95 105。

解题思路:

考察对数组的理解和运用。

c++代码:

#include<bits/stdc++.h>
 
using namespace std;
 
const int N = 55;
 
int h, n;
 
struct node{
    int height;
}a[N];
 
bool cmp(node A, node B)//重载运算符
{
    //如果身高差绝对值不同,按照身高差绝对值由小到大排序
    if (abs(A.height - h) != abs(B.height - h))
        return abs(A.height - h) < abs(B.height - h);
    //身高差绝对值相同,按照身高从小到大排序
    return A.height < B.height;
}
 
int main()
{
    //处理输入
    cin >> h >> n;
    for (int i = 1; i <= n; i ++ )
        cin >> a[i].height;
    
    sort(a + 1, a + n + 1, cmp);
    //输出结果
    for (int i = 1; 
 类似资料: