题目名称
题目描述
某学校举行运动会,学生们按编号(1、2、3.....n)进行标识,
现需要按照身高由低到高排列,
对身高相同的人,按体重由轻到重排列,
对于身高体重都相同的人,维持原有的编号顺序关系。
请输出排列后的学生编号
输入描述
两个序列,每个序列由N个正整数组成,(0 < n <= 100)。
第一个序列中的数值代表身高,第二个序列中的数值代表体重。
输出描述
排列结果,每个数据都是原始序列中的学生编号,编号从1开始。
示例一
输入
4
100 100 120 130
40 30 60 50
Copy
输出
2 1 3 4
Copy
示例一
输入
3
90 110 90
45 60 45
输出
1 3 2
参考解题
student_num = int(input())
height = list(map(int, input().split()))
weight = list(map(int, input().split()))
list_st = list(zip(height, weight))
print(list_st)
st_sort = sorted(list_st, key=lambda x: (x[0], x[1]))
print(st_sort)
student_ord = []
j = 1
for i in list_st:
k = st_sort.index(i) + 1
if k in student_ord:
j = j + 1
student_ord.append(j)
else:
student_ord.append(st_sort.index(i) + 1)
for i in student_ord:
print(i, end=' ')
代码解读
这段代码实现了一个程序,它接收一组学生的身高和体重信息,按照身高和体重排序后输出每个学生的排名。
程序首先读取用户输入的学生数量,以及每个学生的身高和体重信息,并将其分别添加到列表 height 和 weight 中。
然后程序使用 zip 函数将身高和体重信息合并为一个二元组,并将所有学生的信息添加到列表 list_st 中。
接下来,程序使用 sorted 函数对列表 list_st 进行排序,并按照身高从小到大、体重从小到大的顺序排序。
程序将排序后的结果保存在变量 st_sort 中,并将其打印出来。
接着,程序定义了一个空列表 student_ord,用于存储每个学生的排名信息。
程序使用一个 for 循环,依次遍历列表 list_st 中的每个学生,并使用 index 函数在列表 st_sort 中查找该学生的排名。
然后程序将该学生的排名添加到列表 student_ord 中。如果该排名已经在列表 student_ord 中,程序将排名加 1 后再添加到列表中,以避免重复。
在 for 循环中,程序定义了变量 j,用于记录当前的重复学生排名。如果该学生的排名已经在列表 student_ord 中,程序将 j 加 1,
以便为下一个重复学生分配新的排名。
最后,程序使用一个 for 循环,依次输出每个学生的排名信息。
![](https://img-blog.csdnimg.cn/img_convert/719c7e9c62f57e1939874ac9d7cf6bdb.gif)