7-6 學生成績排序 (15 分)
阿新 • • 發佈:2018-12-08
軟體學院第十四次訓練
205 分
- 程式設計題共 9 小題,共計 205 分
剩餘時間: 717:33:11
剩餘時間: 717:33:11
7-6 學生成績排序 (15 分)
假設學生的基本資訊包括學號、姓名、三門課程成績以及個人平均成績,定義一個能夠表示學生資訊的結構型別。輸入n(n<50)個學生的成績資訊,按照學生的個人平均分從高到低輸出他們的資訊。
輸入格式:
輸入一個正整數n(n<50),下面n行輸入n個學生的資訊,包括:學號、姓名、三門課程成績(整數)。
輸出格式:
輸出從高到低排序後的學生資訊,包括:學號、姓名、平均分(保留兩位小數)。
輸入樣例:
3
101 Zhang 78 87 85
102 Wang 91 88 90
103 Li 75 90 84
輸出樣例:
102,Wang,89.67
101,Zhang,83.33
103,Li,83.00
這是大水題,最近太煩了,kmp演算法弄不懂,dijkstra演算法實驗報告寫不出來,我要多看看心理學的書,平復心情
#include<iostream> #include<algorithm> using namespace std; struct stu{ int id; char name[50]; int a,b,c; double avg; }s[55]; bool cmp(stu x,stu y){ return x.avg>y.avg; } int main(){ int n; cin>>n; for(int i=0;i<n;i++){ cin>>s[i].id>>s[i].name>>s[i].a>>s[i].b>>s[i].c; s[i].avg=(s[i].a+s[i].b+s[i].c)/3.0;//注意除以3.0而不是3,否則得不到有效浮點數 } sort(s,s+n,cmp); for(int i=0;i<n;i++){ printf("%d,%s,%.2f\n",s[i].id,s[i].name,s[i].avg); } return 0; }