ACM HDU 1202 The calculation of GPA(簡単な問題)
7070 ワード
The calculation of GPA
Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Submission(s): 9186 Accepted Submission(s): 2110
Problem Description
学期の期末ごとに、みんなは自分の平均成績の計算に忙しいので、この成績は奨学金の評価に直接関係しています.外国の大学はGPA(grade point average)を計算してGPR(grade point ratio)とも呼ばれ、成績点数と単位の重み付け平均値が学生の成績を代表している.ではGPAはどのように計算しますか?
一般大学が採用する採点法
A 90-100 4時
B 80-89 3点
C 70-79 2点
D 60-69 1点
E 0-590点
例えば、ある学生は3つの授業を修習し、その授業目、単位と成績はそれぞれ:
英語:三単位、92点;化学:5単位、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
複数組のデータを含み、各組のデータの第1行には1つの数Nがあり、次にN行は各行に1つの成績を表す.各行に2つの実型の数s,p,sはこの授業の単位を表し,pはその学生の成績(パーセント制)を表す.p=-1なら、その学生のこの授業が欠席したことを説明し、計算すべきではない.
Output
各グループのデータに対して1行出力し、その学生のGPAを表し、2桁の小数を保持する.GPAが存在しない場合は、-1を出力します.
Sample Input
3 3 92 5 80 2 60
Sample Output
2.90
Author
Speakless
Source
Gardon-DYGG Contest 2
Recommend
JGShining
Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Submission(s): 9186 Accepted Submission(s): 2110
Problem Description
学期の期末ごとに、みんなは自分の平均成績の計算に忙しいので、この成績は奨学金の評価に直接関係しています.外国の大学はGPA(grade point average)を計算してGPR(grade point ratio)とも呼ばれ、成績点数と単位の重み付け平均値が学生の成績を代表している.ではGPAはどのように計算しますか?
一般大学が採用する採点法
A 90-100 4時
B 80-89 3点
C 70-79 2点
D 60-69 1点
E 0-590点
例えば、ある学生は3つの授業を修習し、その授業目、単位と成績はそれぞれ:
英語:三単位、92点;化学:5単位、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
複数組のデータを含み、各組のデータの第1行には1つの数Nがあり、次にN行は各行に1つの成績を表す.各行に2つの実型の数s,p,sはこの授業の単位を表し,pはその学生の成績(パーセント制)を表す.p=-1なら、その学生のこの授業が欠席したことを説明し、計算すべきではない.
Output
各グループのデータに対して1行出力し、その学生のGPAを表し、2桁の小数を保持する.GPAが存在しない場合は、-1を出力します.
Sample Input
3 3 92 5 80 2 60
Sample Output
2.90
Author
Speakless
Source
Gardon-DYGG Contest 2
Recommend
JGShining
#include<stdio.h>
int main()
{
int n;
float s,p;
float ts,tp;
while(scanf("%d",&n)!=EOF)
{
ts=0;tp=0;
for(int i=0;i<n;i++)
{
scanf("%f %f",&s,&p);
if(p==-1)continue;
if(p>=90){ts+=s;tp+=s*4;}
else if(p>=80){ts+=s;tp+=s*3;}
else if(p>=70){ts+=s;tp+=s*2;}
else if(p>=60){ts+=s;tp+=s*1;}
else ts+=s;
}
if(ts==0)printf("-1
");
else
printf("%.2f
",tp/ts);
}
return 0;
}