DAY 08 结构体

#include"work1.h"

void menu()
{
	printf("#####1.添加人数####\n");
	printf("#####2.添加信息###\n");
	printf("#####3.输出信息##\n");
	printf("#####4.好坏成绩##\n");
	printf("#####5.清除数据###\n");
	printf("#####6.退出####\n");

}
struct Class* num_1()
{
 struct	Class *ptr=(struct Class*)malloc(sizeof(struct Class));
	if(NULL==ptr)
	{
		printf("开辟失败\n");
		return NULL;
	}
	memset(ptr,0,sizeof(struct Class));
	return ptr;
}
void num_2(struct Class *ptrr)
{
	printf("请输入学生数量:");
	scanf("%d",&ptrr->size);
	printf("输入完成!\n");
}
void num_3(struct Class*ptr)
{
	for(int i=0;i<ptr->size;i++)
	{
		printf("第%d个学生姓名:",i+1);
		scanf("%s",ptr->student[i].name);
		printf("第%d个学生年龄:",i+1);
		scanf("%d",&ptr->student[i].age);
		printf("第%d个学生成绩:",i+1);
		scanf("%lf",&ptr->student[i].score);
	}
	printf("输入完成\n");
}
void num_4(struct Class*ptr)
{
	for(int i=1;i<ptr->size;i++)
	{
		for(int j=0;j<(ptr->size)-1;i++)
		{
			if(ptr->student[i].score>ptr->student[i+1].score)
			{
				ptr->student[i+10]=ptr->student[i+1];
				ptr->student[i+1]=ptr->student[i];
				ptr->student[i]=ptr->student[i+10];
			}
		}
	}
	for(int i =0;i<ptr->size;i++)
	{
		printf("%s\t%d\t%lf\n",ptr->student[i].name,ptr->student[i].age,ptr->student[i].score);

	}
}
void num_5(struct Class*ptr)
{
	double max =ptr->student[0].score;
	int maxi =0;
	for(int i =1;i<(ptr->size);i++)
	{
		if(ptr->student[i].score>max)
		{
			max =ptr->student[i].score;
			maxi=i;
		}
	}
	if(maxi!=0)
	{
		printf("成绩最好的同学:%s\t%d\t%lf\n",ptr->student[maxi].name,ptr->student[maxi].age,ptr->student[maxi].score);

	}
	else
				printf("成绩最好的同学:%s\t%d\t%lf\n",ptr->student[0].name,ptr->student[0].age,ptr->student[0].score);

	
	double man =ptr->student[0].score;
	int mani =0;
	for(int i =1;i<(ptr->size);i++)
	{
		if(ptr->student[i].score<man)
		{
			man =ptr->student[i].score;
			mani=i;
		}
	}
	if(mani!=0)
	{
		printf("成绩最差的同学:%s\t%d\t%lf\n",ptr->student[mani].name,ptr->student[mani].age,ptr->student[mani].score);

	}
	else
				printf("成绩最差的同学:%s\t%d\t%lf\n",ptr->student[0].name,ptr->student[0].age,ptr->student[0].score);
}
void num_6(int **ptr)
{
		*(*ptr)=NULL;
}

 

#include"work1.h"

int main(int argc, const char *argv[])
{
	int a=0;
	struct Class*ptr= num_1();
	do
	{
		menu();
		printf("请选择:");
		scanf("%d",&a);
		switch(a)
		{
			case 1:
				{
					num_2(ptr);
				}
		break;
			case 2:
				{
					num_3(ptr);
				}break;
			case 3:
				{
					num_4(ptr);
					for(int i =0;i<ptr->size;i++)
					{
					printf("%s\t%d\t%lf\n",ptr->student[i].name,ptr->student[i].age,ptr->student[i].score);
					}
				}break;
			case 4:
				{
					num_5(ptr);
				}break;
			case 5:
				{
					printf("数据以清除\n");
					num_6(&ptr);
				}break;
			case 6:
				{
				printf("退出成功");
				goto END;
				}break;
			default:
				{
				printf("输入错误\n");
				}
		}
	}
	while(1);
END:
	return 0;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值