第十四周项目7-3-使用数组输出最高分的学号

/*
*程序的版权和版本声明部分:
*Copyright(c)2013,烟台大学计算机学院学生
*All rights reserved.
*文件名称:
*作者:田成琳
*完成日期:2013年 11月30 日
*版本号:v1.0
*对任务及求解方法的描述部分:
*输入描述: 无
*问题描述:从文件读入n名同学成绩,输出平均成绩,并统计输出优秀人数和不及格人数,最高分的学生学号。 
*程序输出:平均成绩,优秀人数,不及格人数 ,最高分学生学号
*问题分析:
*算法设计:
*/
#include<iostream>
#include<fstream>
#include<cstdlib>
using namespace std;
int main()
{
	int score[10000],max=-99,min=999,f=0,y=0,xiabiao[10000],i=0,youxiu=80,fail=60;
	double ave,sum=0; 
	ifstream infile("D:\\english.dat",ios::in);
	if(!infile)  //其实这里可以不写、、、 
	{
		cerr<<"open error!"<<endl;
		exit(1);
	}
	for(int r=0;r<10000;r++)
	{
		infile>>score[r];
		sum+=score[r];
		if(score[r]>max)
		{
			max=score[r];
		}
		if(score[r]>=youxiu)
		{
			y++;
		}
		if(score[r]<fail)
		{
			f++;
		}
	}
	infile.close();
	for(int n=0;n<10000;n++)
	{
		if(score[n]==max)
		{
			xiabiao[i]=n;
			i++;
		}
	}
	ave=sum/10000;
	cout<<"最高成绩为:"<<max<<endl;
	cout<<"最高成绩的学号为:";
	for(int g=0;g<i;g++)
	{
		cout<<xiabiao[g]<<" ";
	}
	cout<<endl;
	cout<<"平均成绩为:"<<ave<<endl;
	cout<<"优秀人数为:"<<y<<endl;
	cout<<"不及格人数为:"<<f<<endl;
	return 0;
}


运行结果:


心得体会:

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
假设有一个结构体类型为`Student`,包含学生的姓名、学号和成绩三个字段,可以按照以下方式定义: ```c #include <stdio.h> #include <string.h> #define MAX_STUDENTS 100 typedef struct { char name[20]; int id; int score; } Student; ``` 接下来,我们可以定义一个包含多个`Student`类型元素的一维数组或二维数组,然后按照成绩的降序输出学生的姓名、学号和成绩。 一维数组示例代码如下: ```c int main() { Student students[MAX_STUDENTS]; int n, i, j; printf("请输入学生个数:"); scanf("%d", &n); for (i = 0; i < n; i++) { printf("请输入第%d个学生的姓名、学号、成绩:", i + 1); scanf("%s%d%d", students[i].name, &students[i].id, &students[i].score); } // 冒泡排序按成绩降序排列 for (i = 0; i < n - 1; i++) { for (j = 0; j < n - i - 1; j++) { if (students[j].score < students[j + 1].score) { Student tmp = students[j]; students[j] = students[j + 1]; students[j + 1] = tmp; } } } // 输出结果 printf("按成绩降序输出学生信息:\n"); for (i = 0; i < n; i++) { printf("%s %d %d\n", students[i].name, students[i].id, students[i].score); } return 0; } ``` 二维数组示例代码如下: ```c int main() { Student students[MAX_STUDENTS][3]; int n, i, j; printf("请输入学生个数:"); scanf("%d", &n); for (i = 0; i < n; i++) { printf("请输入第%d个学生的姓名、学号、成绩:", i + 1); scanf("%s%d%d", students[i][0].name, &students[i][1].id, &students[i][2].score); } // 冒泡排序按成绩降序排列 for (i = 0; i < n - 1; i++) { for (j = 0; j < n - i - 1; j++) { if (students[j][2].score < students[j + 1][2].score) { Student tmp[3]; memcpy(tmp, students[j], sizeof(Student) * 3); memcpy(students[j], students[j + 1], sizeof(Student) * 3); memcpy(students[j + 1], tmp, sizeof(Student) * 3); } } } // 输出结果 printf("按成绩降序输出学生信息:\n"); for (i = 0; i < n; i++) { printf("%s %d %d\n", students[i][0].name, students[i][1].id, students[i][2].score); } return 0; } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值