OD统一考试(D卷)
分值: 100分
题解: Java / Python / C++
小明今年升学到小学一年级,来到新班级后发现其他小朋友们身高参差不齐,然后就想基于各小朋友和自己的身高差对他们进行排序,请帮他实现排序。
第一行为正整数H和N,0<H<200,为小明的身高,0<N<50,为新班级其他小朋友个数。
第二行为N个正整数H1-HN,分别是其他小朋友的身高,取值范围0<Hi<200 (1<= i <=N),且N个正整数各不相同。
输出排序结果,各正整数以空格分割。和小明身高差绝对值最小的小朋友排在前面,和小明身高差绝对值最大的小朋友排在最后,如果两个小朋友和小明身高差一样,则个子较小的小朋友排在前面。
输入:
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。
这道题属于排序算法的应用。解题思路是计算每个同学的身高与小明身高的差值,然后按照这个差值进行排序,如果差值相同,则按照身高进行排序。接着输出排序后的结果即可。
时间复杂度分析
- Java 和 C++ 版本的时间复杂度为 O(NlogN),其中 N 为小朋友的数量,主要由排序算法决定。
- Python 版本同样是 O(NlogN),排序的时间复杂度为 O(NlogN),遍历输出的时间复杂度为 O(N)。
空间复杂度分析
- Java 和 Python 版本的空间复杂度为 O(N),主要用于存储同学的信息。
- C++ 版本的空间复杂度也是 O(N),存储同学信息的 vector 占用了空间。
import java.util.ArrayList;
import java.util.List;
import java.util.Scanner;
/**
* @author code5bug
*/
public class Main {
public static void main(String[] args) {
Scanner in = new Scanner(System.in);
// 小明身高, 班级其他小朋友个数
int h = in.nextInt(), n = in.nextInt();
// 存放小朋友信息: new int[]{和小明身高差绝对值, 小朋友身高}
List<int[]> hs = new ArrayList<>();
for (int i = 0; i