題目要求
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"]))