【蓝桥OJ:排列与排序】2007普及组:奖学金python实现

该博客介绍了如何使用Python处理 LanQiao 平台上的比赛排名问题。通过创建双端队列并进行排序,实现了对参赛者总成绩的排序,并在总成绩相同的情况下,依据语文成绩进行排名。程序着重于二维数组的排序和元素位置的调整,确保了排名的准确性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

题目链接:https://www.lanqiao.cn/problems/531/learning/
思路:
1.统一输入在总列表,方便进行条件排序
2.提取总列表的前五为得奖名单,按格式输出
代码:

import collections
n=int(input())
lis=collections.deque() #总列表
reword=collections.deque() #得奖列表

for i in range(n):
    stu=list(map(int,input().split())) #输入格式
    stu_add=sum(stu)
    stu.append(i)
    stu.append(stu_add) #把序号和总成绩放在总列表中
    lis.append(stu)

lis=sorted(lis,key=lambda x:x[4],reverse=True) #重点,二维数组的sorted()排序法
for i in range(len(lis)):
    for j in range(len(lis)): #核心算法,交换成绩相同和语文成绩相同的元素
        if lis[i][4]==lis[j][4] and lis[i][0]>lis[j][0]: lis[i],lis[j]=lis[j],lis[i]
        if lis[i][4]==lis[j][4] and lis[i][0]==lis[j][0] and lis[i][3]<lis[j][3]: lis[i],lis[j]=lis[j],lis[i]
            
for i in range(5):
    reword.append(lis[i])
    print(reword[i][3]+1,' ',reword[i][4]) #输出格式

总结:程序重点在于二维数组的列排序,即列排序总成绩的实现方法。算法重点在于相同总成绩和语文成绩相同时的元素位置替换。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

汤米尼克

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值