C基础day8

news2024/11/15 8:22:44

一、思维导图

二、课后习题

#include<myhead.h>
#define Max_Stu 100
//函数声明
//学生信息录入函数
void Enter_stu(int *Num_Stu,char Stu_name[][50],int Stu_score[]);
//查看学生信息
void Print_stu(int Num_Stu,char Stu_name[][50],int Stu_score[]);
//求出成绩最好的学生的成绩
void Best_Stu(int Num_Stu,char Stu_name[][50],int Stu_score[]);
//按姓名升序排序
void Sort_name(int Num_Stu,char Stu_name[][50],int Stu_score[]);
//按成绩对学生升序排序
void Sort_score(int Num_Stu,char Stu_name[][50],int Stu_score[]);

/**********************主函数*************************/
int main(int argc, const char *argv[])
{
	printf("\t\t************学生管理系统*************\n");
	printf("\t\t=======  1、录入学生信息     =======\n");
	printf("\t\t=======  2、查看学生信息     =======\n");
	printf("\t\t=======3、输出成绩最好的学生 =======\n");
	printf("\t\t=======4、按姓名对学生排序   =======\n");
	printf("\t\t=======5、按成绩对学生排序   =======\n");			
	printf("\t\t=======0、      退出         =======\n");			

	//定义二维字符数组存放学生姓名
	//定义一维数组存放学生成绩
	char Stu_name[Max_Stu][50];
	int  Stu_score[Max_Stu];

	int Num_Stu= 0; 		//初始化录入学生人数
	
	//菜单
	int menu =0;
	do
	{
		printf("请输入选项>>>");
		scanf("%d",&menu);
		getchar();

		//多分支选择执行对应功能
		switch(menu)
		{
		case 1://录入学生信息
				//调用信息录入函数
				Enter_stu(&Num_Stu,Stu_name,Stu_score);
				break;
		case 2://查看学生信息
				Print_stu(Num_Stu,Stu_name,Stu_score);
				break;
		case 3://求成绩最高的学生信息
				Best_Stu(Num_Stu,Stu_name,Stu_score);
				break;
		case 4://按姓名升序排序
				Sort_name(Num_Stu,Stu_name,Stu_score);
				break;
		case 5://按成绩对学生升序排序
				Sort_score(Num_Stu,Stu_name,Stu_score);
		case 0://退出
				break;
		default:
				printf("输入错误,请重新输入\n");
				break;
		}

	} while(menu !=0);

	return 0;
}

//学生信息录入函数
void Enter_stu(int *Num_Stu,char Stu_name[][50],int Stu_score[])
{
	//提示输入学生个数,作为参数传给录入函数
	printf("请输入录入学生人数:");
	scanf("%d",Num_Stu);

	//循环输入学生姓名和成绩
	for(int i=0;i< *Num_Stu;i++)
	{
		printf("请输入第%d个学生姓名:",i+1);
		scanf("%s",Stu_name[i]);
		printf("请输入第%d个学生成绩:",i+1);
		scanf("%d",&Stu_score[i]);
	}
	
}

//查看学生信息
void Print_stu(int Num_Stu,char Stu_name[][50],int Stu_score[])
{
	printf("学生信息如下:\n");
	//循环打印学生信息
	for(int i=0;i<Num_Stu;i++)
	{
		printf("姓名:%s,分数:%d\n",Stu_name[i],Stu_score[i]);
	}
}

//求出成绩最好的学生的成绩
void Best_Stu(int Num_Stu,char Stu_name[][50],int Stu_score[])
{
	int max_score = -1; //定义最大成绩容器
	int index =-1; //记录学生数组下标
	//循环比较学生成绩
	for(int i=0;i<Num_Stu;i++)
	{
		if(Stu_score[i] > max_score)
		{
			max_score = Stu_score[i];
			index = i;
		}
	}

	//判断是否有误
	if(index != -1)
		printf("成绩最高的学生:姓名:%s,分数:%d\n",Stu_name[index],Stu_score[index]);
	else
		printf("没有学生信息记录\n");
	
}

//按姓名升序排序
void Sort_name(int Num_Stu,char Stu_name[][50],int Stu_score[])
{
	//定义字符数组替换数组
	//定义分数替换容器
	char tempName[50];
	int tempScore;

	//循环比较并排序
	for(int i =0;i<Num_Stu-1;i++)
	{
		for(int j =0;j<Num_Stu -i-1;j++)
		{
			if(strcmp(Stu_name[j],Stu_name[j+1]) > 0)
			{
				//替换姓名位置
				strcpy(tempName,Stu_name[j]);
				strcpy(Stu_name[j],Stu_name[j+1]);
				strcpy(Stu_name[j+1],tempName);
				
				//替换分数位置
				tempScore = Stu_score[j];
				Stu_score[j] = Stu_score[j+1];
				Stu_score[j+1] = tempScore;
			}
		}
	}
	//打印排序后结果
	printf("学生按姓名排序后的结果:\n");
	for(int i=0;i<Num_Stu;i++)
	{
		printf("姓名:%s,分数:%d\n",Stu_name[i],Stu_score[i]);
	}
}

//按成绩对学生升序排序
void Sort_score(int Num_Stu,char Stu_name[][50],int Stu_score[])
{
	//定义字符数组替换数组
	//定义分数替换容器
	char tempName[50];
	int tempScore;

	//循环比较并排序
	for(int i =0;i<Num_Stu-1;i++)
	{
		for(int j =0;j<Num_Stu -i-1;j++)
		{
			if(Stu_score[j] > Stu_score[j+1])
			{
				//替换姓名位置
				strcpy(tempName,Stu_name[j]);
				strcpy(Stu_name[j],Stu_name[j+1]);
				strcpy(Stu_name[j+1],tempName);
				
				//替换分数位置
				tempScore = Stu_score[j];
				Stu_score[j] = Stu_score[j+1];
				Stu_score[j+1] = tempScore;
			}
		}
	}
	//打印排序后结果
	printf("学生按分数排序后的结果:\n");
	for(int i=0;i<Num_Stu;i++)
	{
		printf("姓名:%s,分数:%d\n",Stu_name[i],Stu_score[i]);
	}

}

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

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

相关文章

Rust vs Go: 特点与应用场景分析

目录 介绍Rust的特点Go的特点Rust的应用场景Go的应用场景总结 介绍 Rust和Go&#xff08;Golang&#xff09;是现代编程语言中两个非常流行的选择。凭借各自的独特优势和广泛的应用场景&#xff0c;吸引了大量开发者的关注。本文将详细介绍Rust和Go的特点&#xff0c;并探讨它…

OpenCV 寻找棋盘格角点及绘制

目录 一、概念 二、代码 2.1实现步骤 2.2完整代码 三、实现效果 一、概念 寻找棋盘格角点&#xff08;Checkerboard Corners&#xff09;是计算机视觉中相机标定&#xff08;Camera Calibration&#xff09;过程的重要步骤。 OpenCV 提供了函数 cv2.findChessboardCorners…

C++ 宏和内联、范围for、nullptr

C 宏函数和内联函数、范围for、nullptr 宏函数和内联函数 ​ 函数重载中提到过&#xff0c;一个程序编译需要经过四个阶段&#xff0c;第一个阶段预处理中有一个操作是宏替换。由于是替换&#xff0c;所以宏不建立栈帧&#xff0c;且没有数据类型的限制&#xff0c;能够提高我…

ESP-12F 异常烧录一例

自己打了一块esp8266 &#xff0c;esp 12f的模组&#xff0c;品牌是B&T ,某公司的子品牌吧。 玩单片机这么久&#xff0c;终于玩到了自己打nodemcu这种版了。 遇到一些问题汇总如下供参考&#xff1a; 1&#xff0c;模组IO2自带了led,后来只能拆了我画的线路&#xff0c;…

Canvas:实现在线画板操作

想象一下&#xff0c;用几行代码就能创造出如此逼真的图像和动画&#xff0c;仿佛将艺术与科技完美融合&#xff0c;前端开发的Canvas技术正是这个数字化时代中最具魔力的一环&#xff0c;它不仅仅是网页的一部分&#xff0c;更是一个无限创意的画布&#xff0c;一个让你的想象…

前后端如何实现非对称加解密-使用RSA为例讲解!

写在最前面&#xff0c;RSA是一种非对称加密算法&#xff0c;使用不同的公钥和私钥进行加密和解密。 下面是使用RSA进行加密和解密的代码示例&#xff1a; 前端&#xff1a;使用CryptoJS进行RSA加密 在前端JavaScript中&#xff0c;使用jsencrypt库来进行RSA加密&#xff1a…

04OLED简介和调试方法

OLED简介和调试方法 调试方式串口调试显示屏调试其他调试方法总结&#xff1a; OLED简介硬件电路OLED驱动函数 keil调试模式进入方法keil调试界面窗口简单功能说明更加强大的功能 调试方式 电脑想看什么变量可以直接打印到屏幕&#xff0c;但是单片机很多时候由于成本和电路结构…

充电桩运营平台的技术方案 53页

充电桩运营平台的技术方案 53页&#xff0c;全套解决方案 内容太多&#xff0c;复制图片丢失&#xff0c;需要完整的私信我。

图片kb太大了怎么改小?修改图片kb的方法介绍

图片kb太大了怎么改小&#xff1f;将图片的文件大小&#xff08;以KB为单位&#xff09;缩小可以带来多种优点&#xff0c;但也有一些缺点需要注意。缩小图片文件大小可以显著减少它在硬盘或其他存储设备上占用的空间&#xff0c;使你能够存储更多的图片和其他文件。而且&#…

Postman使用教程【项目实战】

目录 引言软件下载及安装项目开发流程1. 创建项目2. 创建集合(理解为&#xff1a;功能模块)3. 设置环境变量&#xff0c;4. 创建请求5. 测试脚本6. 响应分析7. 共享与协作 结语 引言 Postman 是一款功能强大的 API 开发工具&#xff0c;它可以帮助开发者测试、开发和调试 API。…

制造业中SCADA与MES系统承担着怎样的重任?

SCADA&#xff08;Supervisory Control and Data Acquisition&#xff09;是一种广泛应用于工业控制系统中的监控和数据采集系统。它主要用于监控和控制工业过程中的设备和活动&#xff0c;并收集相关数据以供分析和优化。SCADA系统由人机界面&#xff08;HMI&#xff09;、数据…

提醒我每天打卡的“目标打卡提醒软件”

在繁忙的生活中&#xff0c;我们总有许多需要每日坚持的习惯&#xff0c;无论是为了健康而设定的减肥计划&#xff0c;还是为了工作而必须的每日上班打卡&#xff0c;亦或是为了自我提升而规定的每日学习任务。这些日常打卡活动&#xff0c;虽然重要&#xff0c;但在忙碌和疲惫…

罗马仕和西圣充电宝好用吗?西圣、倍思充电宝实测大PK!

随着智能设备在日常生活中的普及&#xff0c;充电宝成为了人们出行必备的数码配件。市场上充电宝品牌琳琅满目&#xff0c;其中罗马仕、西圣和倍思是较为知名的品牌。它们各自有着什么样的特点和优势呢&#xff1f;为了帮助大家更好地选择适合自己的充电宝&#xff0c;我们特意…

“我没钱”最好别用“I have no money“,老外很少这样说!成人学英语到柯桥泓畅学校

说到没钱都有话说&#xff0c;那我们怎么用英语表达&#xff1f;是不是直接说I have no money&#xff0c;老外表示很少这样说&#xff0c;那下面一起来拓展下&#xff1a; 老外如何地道表达“我没钱”&#xff1f; 当我们想表达“我没钱”时&#xff0c;很多人的第一反应就是…

opencv 中如何通过欧式距离估算实际距离(厘米)

1&#xff1a;这个方法个人测试觉得是正确的&#xff0c;误差较小&#xff0c;目前满足我当前的需求&#xff0c;如果方法不对&#xff0c;请大家评论&#xff0c;完善。 2&#xff1a;确保拍摄的参照物是垂直的&#xff0c;如果不垂直&#xff0c;就会有误差&#xff0c;不垂…

心电信号降噪前处理(MATLAB R2018)

心电信号降噪方法分析 &#xff08;1&#xff09;基线漂移的常用滤除法是拟合基线抵消法&#xff0c;此法先估计或提取信号基线&#xff0c;然后进行减法运算去掉信号中漂移成分&#xff0c;达到滤波的目的。抑制基线漂移的另一种方法是采用线性相位滤波器&#xff0c;因为基线…

什么是 GC Roots??一文带你看懂!!

什么是 GC Roots &#xff1f; JVM 是如何判断哪些对象应该回收&#xff0c;哪些应该保留呢&#xff1f;GC Roots 堆是一个巨大的对象集合&#xff0c;其中包含许多对象实例。 这些对象在堆中有不同的引用层次。一些接口会被频繁调用&#xff0c;每秒生成大量对象。这些对象之间…

【网络安全】实验七(ISA防火墙的规则设置)

一、实验目的 二、配置环境 1、打开两台虚拟机&#xff0c;并参照下图&#xff0c;搭建网络拓扑环境&#xff0c;要求两台虚拟机的IP地址要按照图中的标识进行设置&#xff0c;并根据搭建完成情况&#xff0c;勾选对应选项。注&#xff1a;此处的学号本人学号的最后两位数字&a…

MVC之 Controller 》》 ModelState ValidationMessageFor ValidationSummary

ModelState是Controller的一个属性&#xff0c;可以被继承自System.Web.Mvc.Controller的那些类访问。它表示在一次POST提交中被提交到服务器的 键值对集合&#xff0c;每个记录到ModelState内的值都有一个错误信息集。尽管ModelState的名字中含有“Model”&#xff0c;但它只有…

Monorepo仓库管理策略之 Lerna

这里写目录标题 前言&#xff1a;一、简介二、新建项目使用安装生成结构 三、复用现有项目执行命令查看包 四、配置package相互引用导入现有的包 五、发布包确定项目版本发布项目添加项目到到git发布包到NPM包发布出错解决方案 五、实例代码 前言&#xff1a; 将大型代码仓库分…