[洛谷]P1051 谁拿了最多奖学金 (#模拟 -1.22)

xiaoxiao2022-06-11  33

题目描述

某校的惯例是在每学期的期末考试之后发放奖学金。发放的奖学金共有五种,获取的条件各自不同:

院士奖学金,每人8000元,期末平均成绩高于80分(>80),并且在本学期内发表1篇或1篇以上论文的学生均可获得;五四奖学金,每人4000元,期末平均成绩高于85分(>85),并且班级评议成绩高于80分(>80)的学生均可获得;成绩优秀奖,每人2000元,期末平均成绩高于90分(>90)的学生均可获得;西部奖学金,每人1000元,期末平均成绩高于85分(>85)的西部省份学生均可获得;班级贡献奖,每人850元,班级评议成绩高于80分(>80)的学生干部均可获得;

只要符合条件就可以得奖,每项奖学金的获奖人数没有限制,每名学生也可以同时获得多项奖学金。例如姚林的期末平均成绩是87分,班级评议成绩82分,同时他还是一位学生干部,那么他可以同时获得五四奖学金和班级贡献奖,奖金总数是4850元。

现在给出若干学生的相关数据,请计算哪些同学获得的奖金总数最高(假设总有同学能满足获得奖学金的条件)。

输入输出格式

输入格式:

第一行是1个整数N(1≤N≤100),表示学生的总数。

接下来的N行每行是一位学生的数据,从左向右依次是姓名,期末平均成绩,班级评议成绩,是否是学生干部,是否是西部省份学生,以及发表的论文数。姓名是由大小写英文字母组成的长度不超过20的字符串(不含空格);期末平均成绩和班级评议成绩都是0到100之间的整数(包括0和100);是否是学生干部和是否是西部省份学生分别用1个字符表示,Y表示是,N表示不是;发表的论文数是00到10的整数(包括0和10)。每两个相邻数据项之间用一个空格分隔。

输出格式:

包括3行。

第1行是获得最多奖金的学生的姓名。

第2行是这名学生获得的奖金总数。如果有两位或两位以上的学生获得的奖金最多,输出他们之中在输入文件中出现最早的学生的姓名。

第3行是这N个学生获得的奖学金的总数。

输入输出样例

输入样例#1

4 YaoLin 87 82 Y N 0 ChenRuiyi 88 78 N Y 1 LiXin 92 88 N N 0 ZhangQin 83 87 Y N 1

输出样例#1

ChenRuiyi 9000 28700

说明

2005提高组第一题

 


思路

这还提高组的题?那我估计都能ak2005年提高组。

#include <stdio.h> #include <iostream> using namespace std; typedef struct { string name;//名字 int score,class_score,passage,prize;//score表示期末总分,class_score表示班级分数,passage表示论文数,prize表示奖金 char classboss,west;//classboss表示班级干部,west表示是不是西部学生 }node; int n,s,maxn(-1<<30);//maxn表示取最大值,s表示n名同学总奖金 node a[101]; int main() { ios::sync_with_stdio(false); cin.tie(0); int i,j; cin>>n; for(i=1;i<=n;i++) { cin>>a[i].name>>a[i].score>>a[i].class_score>>a[i].classboss>>a[i].west>>a[i].passage; } for(i=1;i<=n;i++) {//一系列的模拟开始 if(a[i].score>80 && a[i].passage>0) { a[i].prize+=8000; } if(a[i].score>85 && a[i].class_score>80) { a[i].prize+=4000; } if(a[i].score>90) { a[i].prize+=2000; } if(a[i].score>85 && a[i].west=='Y') { a[i].prize+=1000; } if(a[i].class_score>80 && a[i].classboss=='Y') { a[i].prize+=850; } s=s+a[i].prize;//s加上同学们的奖金 if(a[i].prize>maxn)//找最大值 { maxn=a[i].prize; j=i;//j用来方便找那个奖金最多的同学 } } cout<<a[j].name<<endl<<maxn<<endl<<s<<endl; return 0; }

 

转载请注明原文地址: https://www.6miu.com/read-4930609.html

最新回复(0)