牛客网编程题——成绩排序(堆排序)

在这里插入图片描述

本题最大的难点不是题目本身
而是如何处理牛客网的多组流数据输入输出

from heapq import * 
while True:
    try:
        n = int(input())
        direction = int(input())
        heap = []
        score_dict = {}
        for _ in range(n):
            l = input().split(' ')
            this_score = int(l[1])
            this_name = l[0]
            if this_score not in score_dict:
                score_dict[this_score] = [this_name]
            else:
                score_dict[this_score].append(this_name)
            if direction == 1:
                heappush(heap,this_score) 
            elif direction == 0:
                heappush(heap,-1*this_score)
        for _ in range(n):
            if direction == 1:
                this_score = heappop(heap)
            else:
                this_score = heappop(heap) * -1
            this_person = score_dict[this_score][0]
            score_dict[this_score].pop(0)
            print(this_person + ' ' + str(this_score))
    except:
        break
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值