C基础day8

一、思维导图

二、课后习题

#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("请输入录入学生人数:");
	int NUM = *Num_Stu;
	scanf("%d",Num_Stu);
	getchar();

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

//查看学生信息
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]);
	}
	putchar(10);
}

//求出成绩最好的学生的成绩
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");
		putchar(10);

}

//按姓名升序排序
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]);
	}
	putchar(10);

}

//按成绩对学生升序排序
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]);
	}
	putchar(10);
}
相关推荐
IU宝9 分钟前
C/C++内存管理
java·c语言·c++
qq_4597300313 分钟前
C 语言面向对象
c语言·开发语言
陌小呆^O^1 小时前
Cmakelist.txt之win-c-udp-client
c语言·开发语言·udp
qystca4 小时前
洛谷 B3637 最长上升子序列 C语言 记忆化搜索->‘正序‘dp
c语言·开发语言·算法
网易独家音乐人Mike Zhou9 小时前
【卡尔曼滤波】数据预测Prediction观测器的理论推导及应用 C语言、Python实现(Kalman Filter)
c语言·python·单片机·物联网·算法·嵌入式·iot
搬砖的小码农_Sky12 小时前
C语言:数组
c语言·数据结构
ahadee16 小时前
蓝桥杯每日真题 - 第19天
c语言·vscode·算法·蓝桥杯
Theliars16 小时前
C语言之字符串
c语言·开发语言
Reese_Cool16 小时前
【数据结构与算法】排序
java·c语言·开发语言·数据结构·c++·算法·排序算法
搬砖的小码农_Sky17 小时前
C语言:结构体
c语言·数据结构