历年蓝桥杯Python青少组中/高级选拔赛(STEMA)真题解析 | 2022年12月编程题(9)

本文介绍了如何使用Python实现蓝桥杯比赛的选手成绩排序,包括定义结构体、输入选手信息、使用sorted函数按照分数和编号进行排序,并给出了代码详解和示例输出。
摘要由CSDN通过智能技术生成

学习Python从娃娃抓起!记录下蓝桥杯备考学习过程中的题目,记录每一个瞬间。
附上汇总贴:历年蓝桥杯Python青少组中/高级选拔赛(STEMA)真题解析 | 汇总


【题目描述】
某比赛有N(2≤N≤50)名选手参加,给定每名参赛选手的编号(1到N)和比赛得分(0≤得分≤100),请按照分数从高到低的顺序排序,如果分数相同就按照编号排序,编号小的排前边。
【输入】
第一行输入一个正整数N(2≤N≤50),表示参赛人数
第二行开始,共输入N行,每行两个正整数,分别表示参赛选手的编号和比赛得分(0≤得分≤100),正整数之间以一个空格隔开
【输出】
按照排序规则,输出N行,每行两个正整数,分别表示编号和得分,正整数之间以一个空格隔开
【输入样例】

3
3 84
1 87
2 84

【输出样例】

1 87
2 84
3 84

【代码详解】
[图片]

class student:  # 定义结构体
    def __init__(self):
        self.score = 0
        self.id = 0
a = [student() for i in range(55)]
n = int(input())

for i in range(1, n+1):  # 输入每个选手的成绩和id
    ls = [int(i) for i in input().split()]
    a[i].id = ls[0]
    a[i].score = ls[1]
a1 = sorted(a[1:n+1], key=lambda x:(-x.score, x.id))  # 使用sorted排序,lambda中从大到小使用“-”,否则为从小到大
a = a[0:1]+a1+a[n+1:]  # 拼接a数组
for i in range(1,n+1):  # 按照要求输出
    print(a[i].id, a[i].score)

【运行结果】

3
3 84
1 87
2 84
1 87
2 84
3 84
  • 7
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值