MiYu原创, 转帖请注明 : 转载自 ______________白白の屋
题目地址:
http://acm.hdu.edu.cn/showproblem.php?pid=1202
题目描述:
毫无疑问, 这是一个水题, 但是我悲剧的还是WA 了2次 , 注意到题目的输出要求里有一句话 : 如果 GPA不存在,输出 -1 .
什么时候不存在? 0 ! 只要把这个0 处理好就行了. YM .
代码如下 :
题目地址:
http://acm.hdu.edu.cn/showproblem.php?pid=1202
题目描述:
Problem Description
每学期的期末,大家都会忙于计算自己的平均成绩,这个成绩对于评奖学金是直接有关的。国外大学都是计算GPA(grade point average) 又称GPR(grade point ratio),即成绩点数与学分的加权平均值来代表一个学生的成绩的。那么如何来计算GPA呢?
一般大学采用之计分法
A90 - 100 4 点
B80 - 89 3 点
C70 - 79 2 点
D60 - 69 1 点
E0 - 59 0 点
例如:某位学生修习三门课,其课目、学分及成绩分别为:
英文:三学分、92 分;化学:五学分、80 分;数学:二学分、60分,则GPA的算法如下:
科目 学分 分数 点数 分数×点数
英文 3 92 4 12
化学 5 80 3 15
数学 2 60 1 2
合计 10 29
29/10=2.9
2.9即为某生的GPA
下面有请你写一个用于计算GPA的程序。
Input
包含多组数据,每组数据的第一行有一个数N,接下来N行每行表示一门成绩。每行有两个实型的数 s,p,s表示这门课的学分,p表示该学生的成绩(百分制)。如果p=-1则说明该学生这门课缺考,是不应该计算在内的。
Output
对每组数据输出一行,表示该学生的GPA,保留两位小数。如果GPA不存在,输出-1。
Sample Input
3
3 92
5 80
2 60
Sample Output
2.90
每学期的期末,大家都会忙于计算自己的平均成绩,这个成绩对于评奖学金是直接有关的。国外大学都是计算GPA(grade point average) 又称GPR(grade point ratio),即成绩点数与学分的加权平均值来代表一个学生的成绩的。那么如何来计算GPA呢?
一般大学采用之计分法
A90 - 100 4 点
B80 - 89 3 点
C70 - 79 2 点
D60 - 69 1 点
E0 - 59 0 点
例如:某位学生修习三门课,其课目、学分及成绩分别为:
英文:三学分、92 分;化学:五学分、80 分;数学:二学分、60分,则GPA的算法如下:
科目 学分 分数 点数 分数×点数
英文 3 92 4 12
化学 5 80 3 15
数学 2 60 1 2
合计 10 29
29/10=2.9
2.9即为某生的GPA
下面有请你写一个用于计算GPA的程序。
Input
包含多组数据,每组数据的第一行有一个数N,接下来N行每行表示一门成绩。每行有两个实型的数 s,p,s表示这门课的学分,p表示该学生的成绩(百分制)。如果p=-1则说明该学生这门课缺考,是不应该计算在内的。
Output
对每组数据输出一行,表示该学生的GPA,保留两位小数。如果GPA不存在,输出-1。
Sample Input
3
3 92
5 80
2 60
Sample Output
2.90
毫无疑问, 这是一个水题, 但是我悲剧的还是WA 了2次 , 注意到题目的输出要求里有一句话 : 如果 GPA不存在,输出 -1 .
什么时候不存在? 0 ! 只要把这个0 处理好就行了. YM .
代码如下 :
//MiYu原创, 转帖请注明 : 转载自 ______________白白の屋
#include <iostream>
#include <iomanip>
using namespace std;
int hash[11] = { 0, 0, 0, 0, 0, 0, 1, 2, 3, 4, 4 };
int main ()
{
int T;
while ( cin >> T )
{
double total = 0 , pnt = 0, scr = 0 , mlt = 0;
while ( T -- )
{
cin >> pnt >> scr;
if ( scr == -1 )
{
continue;
}
total += pnt;
mlt += pnt * hash[ (int)scr / 10 ];
}
if ( total < 1e-5 )
{
cout << -1 << endl;
continue;
}
cout << setprecision (2) << setiosflags ( ios::fixed ) << mlt * 1.0 / total << endl;
}
return 0;
}
#include <iostream>
#include <iomanip>
using namespace std;
int hash[11] = { 0, 0, 0, 0, 0, 0, 1, 2, 3, 4, 4 };
int main ()
{
int T;
while ( cin >> T )
{
double total = 0 , pnt = 0, scr = 0 , mlt = 0;
while ( T -- )
{
cin >> pnt >> scr;
if ( scr == -1 )
{
continue;
}
total += pnt;
mlt += pnt * hash[ (int)scr / 10 ];
}
if ( total < 1e-5 )
{
cout << -1 << endl;
continue;
}
cout << setprecision (2) << setiosflags ( ios::fixed ) << mlt * 1.0 / total << endl;
}
return 0;
}