OJ题——11. Olympic Game

题目描述

2012伦敦奥运会即将到来,大家都非常关注奖牌榜的情况,现在我们假设奖牌榜的排名规则如下:

  1. 1、首先gold medal数量多的排在前面;
    2、其次silver medal数量多的排在前面;
    3、然后bronze medal数量多的排在前面;
    4、若以上三个条件仍无法区分名次,则以国家名称的字典序排定。

我们假设国家名称不超过20个字符、各种奖牌数不超过100,且大于等于0。

解答要求时间限制:1000ms, 内存限制:64MB

输入

第一行输入一个整数N(0<N<21),代表国家数量;
然后接下来的N行,每行包含一个字符串Namei表示每个国家的名称,和三个整数Gi、Si、Bi表示每个获得的gold medal、silver medal、bronze medal的数量,以空格隔开,如(China 51 20 21),具体见样例输入。

输出

输出奖牌榜的依次顺序,只输出国家名称,各占一行,具体见样例输出。

 

首先我们要注意题目中对奖牌数的排序和对国家名称的排序是不一样的,对奖牌数是从大到小,对国家名称是按照字典序排列的,为了便于进行排序,我们可以将奖牌数前面天津爱一个负号,这样使两个排序的元素都从小到大,具体Python代码如下:

import bisect


def func():
    n = int(input().strip())
    alist = []
    for i in range(n):
        name, gold, silver, bronze = input().strip().split()  # 获取每一行的数据
        gold, silver, bronze = -int(gold), -int(silver), -int(bronze)  # 将奖牌数变为负数并与排序
        atup = tuple((gold, silver, bronze, name))  # 将需要排序的奖牌数和国家名称加入到元组中
        bisect.insort(alist, atup)  # 调用bisect方法对每个加入的元素进行排序
    for tmp in alist:
        print(tmp[3])


if __name__ == "__main__":
    func()
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值