分配补题题集2

个人观点,如有不同见解,欢迎留言

题目:

期末考试前C语言组织了一次测试,统计出了每个学生的成绩(整数),并计算了全班的平均分AVE(整数)。创建了4个补题题集,编号分别为1,2,3,4,题目数依次递减。根据测试成绩分配每个题集学生名单,测试成绩位于区间[AVE+10,100],[AVE,AVE+10),[AVE-10,AVE),[0,AVE-10)分别对应题集1,2,3,4。请你编程帮助老师实现题集分配。

输入格式:

输入在一行中给出正整数N(≤10)。 随后N行,每行给出一位学生的信息,格式为“学号 姓名 测试成绩”,中间以空格分隔。其中学号由12个数字组成的字符串、姓名为长度小于20的不包含空白字符的非空字符串、测试成绩为[0,100]区间内的整数。

输出格式:

首先在一行中输出全部学生测试成绩的平均分(整数),接下来一行输出测试成绩低于平均分的人数,然后按照输入顺序,每行输出一位测试成绩低于平均分的学生的学号、姓名、测试成绩、分配的题集编号,间隔一个空格。

输入样例:

3
201410300106 wanyun 70
201618050322 zhangyu 59
201509210118 lixiao 80
 

输出样例:

69
1
201618050322 zhangyu 59 3
 

代码:

using namespace std;
struct student {
	long long num;
	int grade,rank;
	char name[21];
};
int main() {
	int n,ave=0,underave=0;
	cin>>n;
	student stu[n];
	for(int i=0; i<n; i++) {
		cin>>stu[i].num>>stu[i].name>>stu[i].grade;
		ave+=stu[i].grade;
	}
	ave/=n;
	for(int i=0; i<n; i++) {
		if(stu[i].grade>=ave+10)
			stu[i].rank=1;
		else if(stu[i].grade<ave+10&&stu[i].grade>=ave)
			stu[i].rank=2;
		else if(stu[i].grade<ave-10) {
			stu[i].rank=4;
			underave++;
		} else {
			stu[i].rank=3;
			underave++;
		}
	}
	cout<<ave<<endl<<underave<<endl;
	for(int i=0; i<n; i++)
		if(stu[i].rank==3||stu[i].rank==4)
			cout<<stu[i].num<<" "<<stu[i].name<<" "<<stu[i].grade<<" "<<stu[i].rank<<endl;
}

猜你喜欢

转载自www.cnblogs.com/cwy545/p/12810963.html
今日推荐