Python實現 1178:成績排序


題目要求

1178:成績排序


時間限制: 1000 ms         內存限制: 65536 KB
提交數: 30745     通過數: 12517

【題目描述】

給出班里某門課程的成績單,請你按成績從高到低對成績單排序輸出,如果有相同分數則名字字典序小的在前。

【輸入】

第一行為n (0 < n < 20),表示班里的學生數目;

接下來的n行,每行為每個學生的名字和他的成績, 中間用單個空格隔開。名字只包含字母且長度不超過20,成績為一個不大於100的非負整數。

【輸出】

把成績單按分數從高到低的順序進行排序並輸出,每行包含名字和分數兩項,之間有一個空格。

【輸入樣例】

4
Kitty 80
Hanmeimei 90
Joey 92
Tim 28

【輸出樣例】

Joey 92
Hanmeimei 90 
Kitty 80
Tim 28


分析
這是一道常規的排序題,用python的列表加字典實現類似結構體的功能(用於存儲姓名和對應的分數),最后用冒泡排序輸出;
a=[]
swp={}
num=int(input())
for i in range(num):
    b=input().split()
    b[1]=int(b[1])
    a.append({"name":b[0],"fs":b[1]})   #實現結構體
for i in range(num):
    for j in range(i+1,num):
        if a[i]["fs"]<a[j]["fs"] or (a[i]["fs"]==a[j]["fs"] and a[i]["name"]>a[j]["name"]):
            swp=a[i]
            a[i]=a[j]
            a[j]=swp   #冒泡排序
for i in range(num):
    print("%s %d"%(a[i]["name"],a[i]["fs"]))

  


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM