1. 程式人生 > >7-6 學生成績排序 (15 分)

7-6 學生成績排序 (15 分)

軟體學院第十四次訓練


205 分

  1. 程式設計題共 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;
}