首页 > 其他分享 >杭电1202--学分

杭电1202--学分

时间:2023-02-06 21:01:40浏览次数:64  
标签:&& di -- sumS GPA 1202 杭电 学分 sumD


The calculation of GPA

Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)
Total Submission(s): 24013 Accepted Submission(s): 5610

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

代码:

include <iostream>
# include <cstdio>
# include <algorithm>
using namespace std;



int main(){

int n,i,j,k;
double s,p;
int di;

while(scanf("%d",&n)!=EOF){


double sumS=0,sumD=0;
int flag = 0;
for(i=0;i<n;i++){
scanf("%lf%lf",&s,&p);

if(p>=90&&p<=100){
di = 4;
sumS+=s;
sumD+=di*s;
}else if(p>=80&&p<90){
di = 3;
sumS+=s;
sumD+=di*s;
}else if(p>=70&&p<80){
di = 2;
sumS+=s;
sumD+=di*s;
}else if(p>=60&&p<70){
di = 1;
sumS+=s;
sumD+=di*s;
}else if(p>=0&&p<60){
di = 0;
sumS+=s;
sumD+=di*s;
}


}

if(sumS==0)
printf("-1\n");
else
printf("%.2lf\n",sumD/sumS);
}
return 0;
}


标签:&&,di,--,sumS,GPA,1202,杭电,学分,sumD
From: https://blog.51cto.com/u_15955675/6040513

相关文章

  • 杭电1205--吃糖
    吃糖果ProblemDescriptionHOHO,终于从Speakless手上赢走了所有的糖果,是Gardon吃糖果时有个特殊的癖好,就是不喜欢将一样的糖果放在一起吃,喜欢先吃一种,下一次吃另一种,这样;可......
  • 南阳理工--103背包问题
    背包问题难度:3描述现在有很多物品(它们是可以分割的),我们知道它们每个物品的单位重量的价值v和重量w(1<=v,w<=10);如果给你一个背包它能容纳的重量为m(10<=m<=20),你所要做的就......
  • 杭电1163--9余项定理的例子
    #include<iostream>#include<cstdio>#include<algorithm>usingnamespacestd;intmain(){intn,a[10009];inti,t;while(scanf("%d",&n),n!=0){......
  • 9余数定理
    9余数定理可以验证灯饰两边是否相等......
  • 基于Simulink的RBF神经网络的LMS自适应滤波器设计仿真
    1.算法描述LMS(LeastMeanSquare),由Widrow和Hoff于1960年提出,也称Δ规则。该算法与感知器网络的学习算法在权值调整上都基于纠错学习规则,但LMS更易实现,因此得到广......
  • RCU-1——内核文档翻译——RCU-tasks
    一、TheRCU-taskssubsystem:https://lwn.net/Articles/607117/翻译读取-复制-更新(RCU)机制负责保留旧版本的数据结构,直到它知道没有CPU可以保存对它们的引用;一旦发生......
  • 52.Toad for Oracle 使用说明
    一.Toad功能综述 二.系统需求 三.安装指南 四.快速入门 1.Schemabrowser的用法简介 2.SQEditor的使用介绍 3.ProcedureEditor的用法介绍 4.如何进行PLSQL的debug 5.如何......
  • Java Object类
    默认情况下,Object类是java中所有类的父类。换句话说,它是java的顶级类。如果想引用你不知道的类型的对象,使用Object类是没有错的。请注意,父类引用变量可以引用子类对象,称......
  • drf 自动生成路由
    目录drf路由系统SimpleRouter与DefaultRouteraction装饰器扩展测试伪代码drf路由系统由于继承了ViewSetMinxin类路由的写法变了,有三种写法。需要学习一下原生写法pa......
  • free download glTF models All In One
    freedownloadglTFmodelsAllInOneglTF2.0https://github.com/KhronosGroup/glTFhttps://www.khronos.org/files/gltf20-reference-guide.pdfglTF2.0models......