程序设计综合实习(C语言):学生成绩单制作

news2024/11/25 18:42:17

一、目的

1.掌握结构体变量及数组的定义、赋值、初始化、输入、输出

2.结构体数组的操作。

二、实习环境

Visual Stdio 2022

三、实习内容、步骤与要求

1.定义一个结构体数组,存放10个学生的学号,姓名,三门课的成绩

2.从键盘输入10个学生的以上内容

3.输出单门课成绩最高的学生的学号、姓名、以及该门课程的成绩

4.输出三门课程的平均分数最高的学生的学号、姓名及其平均分

5.将10个学生按照平均分数从高到低进行排序,输出结果,格式如下所示:

number     name   math   Chinese   English    average

103        tom    90      90       100           95

101      alice    90      80       70            80

6.在实习报告中画出程序流程图,说明程序设计的算法,附主要程序段及运行结果(屏幕截图)。

7.在实习报告中说明知识点。

8.在实习报告中说明程序设计过程中的难点、解决办法及编程小结或体会。

四、程序流程图、算法及运行结果

程序流程图

 算法描述

1.定义结构体数组,存放学号,姓名,三门课的成绩。
2.输入10个学生的学号,姓名,三门课的成绩。
3.计算每个学生的平均分。
4.遍历学生数组,通过获取每个学生的成绩,计算出数学成绩最高、语文成绩最高、英语成绩最高、平均分最高单科最高成绩。具体实现方式是,维护一个最大值变量,和一个下标指针,依次遍历每个学生,若发现该学生的指定成绩超过了最大值,则更新最大值,并将该学生的下标记录在对应的下标指针中。若有多个学生的指定成绩都等于最大值,则将多个学生的下标都分别记录在下标指针数组中。
5.遍历学生数组,通过获取每个学生的成绩,统计出数学、语文、英语以及平均分数最高的学生人数。具体实现方式是,遍历每个学生,若该学生的指定成绩等于最高成绩,则将该学生的下标记录在对应的人数记录器以及下标指针数组中。
6.输出数学成绩最高的学生信息。
7.输出语文成绩最高的学生信息。
8.输出英语成绩最高的学生信息。
9.输出平均分数最高的学生信息。
10.将学生数组按照平均分数从高到低排序,通过选择排序实现
11.输出学生信息表格,包括学号、姓名、三科成绩以及平均分数。

 程序代码

#include<stdio.h>
#include<string.h>
//定义结构体数组,存放学号,姓名,三门课的成绩
struct stu
{
	char num[100];
	int math, chinese, english;
	double ave;
	char name[100];
};
int imaxm[100], imaxc[100], imaxe[100],iave[100];分别记录三门课成绩最高的下标,以及平均分成绩最高的下标
int max1, max2, max3;
double max4;//记录三门课的单科最高成绩以及平均分的最高成绩
int cnt1, cnt2, cnt3,cnt4;//若某门课成绩最高不止一个人,则记录成绩最高的人数
int main()
{
	struct stu s[10];
	int i,j;
	double temp;
	char tmp[100];
	printf("输入10个学生的学号,姓名,三门课的成绩(分别为math,chines,english):\n");
	//输入10个学生的学号,姓名,三门课的成绩
	for (i = 0; i < 10; i++) scanf("%s%s%d%d%d",s[i].num,s[i].name,& s[i].math, &s[i].chinese, &s[i].english);
	//算出每个学生的平均分
	for (i = 0; i < 10; i++) s[i].ave = (double)(s[i].math + s[i].chinese + s[i].english) / 3;
	//先将第一个学生的三科成绩视作最高分,通过和其它学生分数的比较得到三科单科最高成绩
	max1 = s[0].math;
	max2 = s[0].chinese;
	max3 = s[0].english;
	max4 = s[0].ave;
	for (i = 1; i < 10; i++)
	{
		if (s[i].math > max1) max1=s[i].math;//max1记录math成绩最高分
		if (s[i].chinese > max2) max2=s[i].chinese;//max2记录chinese成绩最高分
		if (s[i].english > max3) max3=s[i].english;//max3记录english成绩最高分
		if (s[i].ave > max4) max4 = s[i].ave;//max4记录ave成绩最高分
	}
	//通过再次比较看单科有几个学生成绩最高
	for (i = 0; i < 10; i++)
	{
		if (s[i].math == max1)
		{
			cnt1++;
			imaxm[cnt1] = i;
		}
		if (s[i].chinese == max2)
		{
			cnt2++;
			imaxc[cnt2] = i;
		}
		if (s[i].english == max3)
		{
			cnt3++;
			imaxe[cnt3] = i;
		}
		if (s[i].ave == max4)
		{
			cnt4++;
			iave[cnt4] = i;
		}
	}
	printf("math成绩最高:\n");
	for(i=1;i<=cnt1;i++)
	 printf("学号:%s 姓名:%s 成绩:%d\n", s[imaxm[i]].num, s[imaxm[i]].name, s[imaxm[i]].math);
	printf("chinese成绩最高:\n");
	for(i=1;i<=cnt2;i++)
	 printf("学号:%s 姓名:%s 成绩:%d\n", s[imaxc[i]].num, s[imaxc[i]].name, s[imaxc[i]].chinese);
	printf("english成绩最高:\n");
	for(i=1;i<=cnt3;i++)
	 printf("学号:%s 姓名:%s 成绩:%d\n", s[imaxe[i]].num, s[imaxe[i]].name, s[imaxe[i]].english);
	printf("三门课程的平均分最高:\n");
	for (i = 1; i <= cnt4; i++)
	 printf("学号:%s 姓名:%s 成绩:%.2f\n", s[iave[i]].num, s[iave[i]].name, s[iave[i]].ave);
	//10个学生按照平均分数从高到低进行排序
	for (i = 0; i < 9; i++)
		for (j = i + 1; j < 10; j++)
		{
			if (s[i].ave < s[j].ave)
			{
				temp = s[i].math, s[i].math = s[j].math ,s[j].math = temp;
				temp = s[i].chinese, s[i].chinese = s[j].chinese, s[j].chinese = temp;
				temp = s[i].english, s[i].english = s[j].english, s[j].english = temp;
				temp = s[i].ave, s[i].ave = s[j].ave, s[j].ave = temp;
				strcpy(tmp, s[i].num), strcpy(s[i].num, s[j].num), strcpy(s[j].num,tmp);
				strcpy(tmp, s[i].name), strcpy(s[i].name, s[j].name), strcpy(s[j].name, tmp);
			}
		}
	printf("10个学生按照平均分数从高到低进行排序:\n");
	    printf("num        name         math        chinese        english        average\n");
	for (i = 0; i < 10; i++)
		printf("%-10s%-6s%12d%10d%15d%17.2f\n", s[i].num, s[i].name, s[i].math, s[i].chinese, s[i].english, s[i].ave);
	return 0;
}

运行结果 

 

五、知识点、难点及解决办法。

知识点

1.结构体:定义了一个名为”stu”的结构体,其中包含了学号、姓名、三门课的成绩以及平均分(ave)等成员变量。
2.数组:使用了结构体数组s[10]存储了10个学生的信息。
3.遍历数组:用for循环遍历了结构体数组s,实现输入和计算每个学生的平均分。
4.比较大小:通过比较得到了三门课的单科最高成绩以及平均分的最高成绩。同时也用for循环和if语句得到了每门课成绩最高的学生。
5.排序:使用选择排序对10个学生按照平均分数从高到低进行排序。
6.输入输出:使用了scanf函数输入,printf函数输出学生的信息。
7.字符串操作:主要用于存储和打印学生的学号和姓名,使用了strcpy函数进行字符串的复制。

难点及解决方法

1.最高成绩可能不止一个人,可能有多个人成绩相同,所以先求出最高成绩,再找出和最高成绩相同分数的学生并记录下来

2.字符串是常量,不是变量,因此不能直接用等号赋值,所以交换时用中间变量字符串来作为中转站,用strcpy实现赋值

3.最后要输出学生信息表格,要想美观,需使用%5d等,来使得数据整齐

4.排序时需要多个属性交换,切不可只交换平均分数

六、编程小结或体会。

这是一段使用C语言编写的学生成绩统计程序,实现了对10个学生的学号、姓名、数学、语文、英语三门课程成绩的输入、计算平均分、求出每个科目的最高分以及平均分的最高分、按照平均分从高到低排序等功能,知识点比较基础,但是要注意很多细节,比如最高成绩可能不止一个人,字符串常量不能直接用等号赋值,排序时要交换多个属性,通过写这个程序,对结构体有了更进一步的理解,认识到了结构体关于数据管理的巨大优势

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/598953.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Linux 设备树文件手动编译的 shell 脚本

前言 前面通过 Makefile 实现手动编译 Linux 设备树 dts 源文件及其 设备树依赖 dtsi、.h 头文件&#xff0c;如何写成一个 shell 脚本&#xff0c;直接编译呢&#xff1f; 其实就是 把 Makefile 重新编写为 shell 脚本即可 编译设备树 shell 脚本 脚本内容如下&#xff1a…

【六一 iKun】Happy LiuYi, iKuns

六一了&#xff0c;放松下。 Python iKun from turtle import * screensize(1000,1000) speed(6)#把衣服画出来&#xff0c;从右肩膀开始#领子 penup() goto(-141,-179) pensize(3) fillcolor("black") pencolor("black") begin_fill() pendown() left(1)…

【Python实战】Python采集高校信息

前言 大家好,我们今天来爬取某站的高校名单,把其高校名单,成员和内容数获取下来,不过,我们发现这个网站比我们平时多了一个验证,下面看看我是怎么解决的。 环境使用 python 3.9pycharm模块使用 requests模块介绍 requests requests是一个很实用的Python HTTP客户端…

【线性dp必学四道题】线性dp四道经典例题【最长上升子序列】、【最长公共子序列】、【最长公共上升子序列(maxv的由来)】【最长公共子串】

【最长上升子序列】、【最长公共子序列】、【最长公共上升子序列】 最长上升子序列f[i] 表示以i结尾的最长子序列 最长公共子序列f[i][j] 表示 a前i 和 b前j个 最长公共长度 最长公共上升子序列f[i][j]代表所有a[1 ~ i]和b[1 ~ j]中以b[j]结尾的公共上升子序列的集合 最长公共子…

Spring Boot如何实现分布式追踪和监控

Spring Boot如何实现分布式追踪和监控 在分布式系统中&#xff0c;由于服务数量的增加和服务之间的相互调用&#xff0c;会出现跨服务的请求链路较长&#xff0c;难以追踪问题和定位性能瓶颈等问题。因此&#xff0c;分布式追踪和监控变得越来越重要。本文将介绍如何使用 Spri…

怎样一元钱部署自己的AI网站

前段时间我开发了一个简洁的AI问答网站&#xff0c;好多朋友感兴趣&#xff0c;因此我将网站代码在github上开源&#xff0c;并编写此教程&#xff0c;帮助大家快速部署自己的AI网站&#xff0c;会编程的朋友们也可在此基础上定制开发。 前提条件&#xff1a;有自己的ChatGPT账…

AI实战营:开源计算机视觉神器OpenMMLab

目录 OpenMMLab概述 OpenMMLab各开源算法库详细介绍 OpenMMLab开源生态 OpenMMLab概述 部署框架&#xff1a;MMdeploy 算法框架&#xff1a;MMPretrain预训练多模态、MMDetection目标检测、MMDetection3D目标检测、MMRotate旋转目标检测、MMSegmentation语义分割、MMPose姿…

操作系统_进程

操作系统_进程 1 冯•诺依曼体系结构2 操作系统&#xff08;Operator System&#xff09;2.1 设计OS的目的2.2 OS的定位 3 进程3.1 什么是进程&#xff1f;3.2 查看进程3.3 通过fork创建进程使用 if 进行分流如何杀死一个进程 3.4 进程状态R - 运行状态S - 浅睡眠状态D - 磁盘休…

Java中关于ConditionObject的signal()方法的分析

代码块的展示 isHeldExclusively()这个仅持有锁资源的方法&#xff0c;在ReentrantLock中重写进行判断&#xff0c;要是没有持有锁资源那么会返回false&#xff0c;就会出现直接抛异常IllegalMonitorStateException&#xff08;非法监视器状态异常&#xff09;获取排在Conditi…

zookeeper相关,安装,认识......

目录 Zookeeper 1 第一章 Zookeeper简介... 1 1.1 Zookeeper概述和功能... 1 1.2 Zookeper安装... 1 1.3 Zookeper数据模型... 3 第二章 Zookeeper命令操作... 4 1.1 Zookeeper Client 4 1.2 Zookeeper JavaClient 6 第三章 集群角色... 28 Zookeeper 第一章 Zookeepe…

详解Servlet API

目录 前言 HttpServlet HttpServletRequest 代码实例 打印请求信息 通过URL中的queryString进行传递。 通过post请求的body&#xff0c;使用form表单传递 通过POST 请求中的 body 按照 JSON 的格式进行传递 HttpServletResponse 核心方法代码实例 设置状态码 自动刷…

【C++初阶】string 类的认识与学习

在学习string类之前&#xff0c;先在这里推荐2个好用的网站&#xff0c;可以用来查阅C的相关知识 https://cplusplus.com https://en.cppreference.com/w/ 上面的是非官方的&#xff0c;下面的官方的&#xff0c;但是个人感觉还是上面的好用。 一.string 类是什么 简单来说&…

State of GPT (ChatGPT 原理及现状介绍)

State of GPT 演讲信息&#xff1a; 演讲人&#xff1a;Andrej Karpathy (现在OpenAI任职)&#xff0c;之前是特斯拉视觉研发负责人&#xff0c;斯坦福深度学习入门课程 CS231N 讲师演讲主题&#xff1a;受到微软 BUILD2023 邀请&#xff0c;介绍 GPT 的原理及研发现状&#x…

VMware虚拟机安装Ubuntu 22.04详细教程(2023年新版教程)

VMware虚拟机安装Ubuntu 22.04详细教程&#xff08;保姆级教程&#xff09; 大家好&#xff0c;我是洲洲&#xff0c;欢迎关注&#xff0c;一个爱听周杰伦的程序员。关注公众号【程序员洲洲】即可获得10G学习资料、面试笔记、大厂独家学习体系路线等…还可以加入技术交流群欢…

代码创作世界——pytorch深度学习框架数据类型

代码创作世界——pytorch深度学习框架数据类型 torch中的数据类型张量&#xff08;tensor&#xff09; pytorch中的 在数学中&#xff0c;一个单独的数可以成为标量&#xff0c;一行或者一列数组可以称为向量&#xff0c;一个二维数组称为一个矩阵&#xff0c;矩阵中的每一个元…

编译安装nginx服务

目录 编译安装nginx服务 1.关闭防火墙&#xff0c;将安装nginx所需软件包传到/opt目录下 2.安装依赖包 3.创建运行用户、组&#xff08;Nginx服务程序默认以nobody身份运行&#xff0c;建议为其创建专门的用户账号&#xff0c;以便更准确的控制访问权限&#xff09; 4.编译…

11.PasswordEncoder详解与实战

security/day07 这节课我们开始讲PasswordEncoder&#xff0c;如果大家还有印象的话&#xff0c;我们前面有提到过PasswordEncoder: 为什么密码使用{noop}开头呢&#xff1f;我们也做出了相应的解释&#xff0c;这节课开始带大家真正的了解PasswordEncoder, PassworderEncoder…

Android以aar包形式引入hunter-timing,Java(4)

Android以aar包形式引入hunter-timing&#xff0c;Java&#xff08;4&#xff09; &#xff08;1&#xff09;参照这篇文章&#xff1a; https://zhangphil.blog.csdn.net/article/details/130603231https://zhangphil.blog.csdn.net/article/details/130603231 生成.aar文件…

路径规划算法:基于象群优化的路径规划算法- 附代码

路径规划算法&#xff1a;基于象群优化的路径规划算法- 附代码 文章目录 路径规划算法&#xff1a;基于象群优化的路径规划算法- 附代码1.算法原理1.1 环境设定1.2 约束条件1.3 适应度函数 2.算法结果3.MATLAB代码4.参考文献 摘要&#xff1a;本文主要介绍利用智能优化算法象群…

python基础知识(六):列表

目录 1. 列表及其创建2. 列表的特点3. 获取指定元素的索引4. 获取列表中指定索引的元素5. 列表的切片操作6. 列表元素的判断及遍历7. 列表元素的添加操作8. 列表的删除9. 列表元素的修改10. 列表元素的排序11. 列表生成式 1. 列表及其创建 列表由一系列按特定顺序排列的元素组…