C语言对于结构体的赋值 输出操作
有个同学让我帮忙做一下他的C语言作业,是用结构体来管理学生成绩,在前面也写过一个学生管理系统,比较系统(点我跳至),相比于来说这是很简单一个项目,但是以前都是听说结构体,没有实际应用过,下午便边学边写试了一下,也不亏一个多小时的百度,最后还是写出来了了
- 先看一下题目要求
有N个学生,每个学生的数据包括学号、姓名、M门课的成绩,要求:
⑴ 从键盘输入N个学生的数据;
⑵ 求出每门课的平均成绩;
⑶ 求出每个学生的平均成绩;
⑷ 查找指定学号的成绩信息,有则输出成绩等信息,无则输出“查无此人”。
运行结果示例: - 按照题目要求还是写出来了,可能不是很完美,但实现了基本功能,粘代码
#include "iostream.h"
#include "string.h"
#include "stdio.h"
#define N 4//这个应该是学生人数
#define M 5//这个应该是课程数量
int i,j;//定义循环变量
int Average_score=0;//定义平均成绩
char Query[1][12];//定义查询中间变量
struct student
{
char num[12];
char name[20];
int score[M];
};
void input(struct student stu[])//学生信息输入
{
printf("请输入学生情况:\n");
printf("学号\t姓名\t课1\t课2\t课3\t课4\t课5\t\n");
for(i=0;i<4;++i)//四名同学 循环四次
{
scanf("%s%s%d%d%d%d%d",&stu[i].num,&stu[i].name,&stu[i].score[0],&stu[i].score[1],&stu[i].score[2],&stu[i].score[3],&stu[i].score[4]);//结构体输入语句
}
}
void danke(struct student *p)
{
printf("\n");
printf("输出单科结果:\n");
for(j=0;j<5;j++)//有5科 循环五次
{
Average_score = 0;//每次循环前必须置0 否则计算出错
for(i=0;i<4;i++)//有四名同学求这四名同学平均成绩得一个个取
{
Average_score = Average_score + p[i].score[j];//将取得的数与上一个取得的数相加
}
printf("课程%d平均分:%d\n",j+1,Average_score/5);//将四名同学的成绩之和除以5得平均成绩
}
printf("\n");
}
void everyone(struct student *p)
{
printf("输出学生结果:\n");
for(i=0;i<4;i++)//有四名同学 循环四次
{
Average_score = 0;//此处对平均值赋值并无实际作用 为了增强代码美观性
Average_score = (p[i].score[0] + p[i].score[1] + p[i].score[2] + p[i].score[3] + p[i].score[4])/5;//将一名学生的成绩累加且除以5 得出平均成绩
printf("学生%s的平均分:%d\n",p[i].name,Average_score);//输出该生平均成绩
}
printf("\n");
}
void seek(struct student *p)
{
printf("输入查成绩学生的学号:");
scanf("%s",Query[0]);//将用户输入要查询学生的姓名先存入这个二维数组 至于为什么用二维数组 因为方便
for(i=0;i<4;i++)//一共有四名同学 从第一名同学开始查询一直查询到第四名 期间若查询到被查询同学 进入下面if语句
{
if(strcmp(p[i].num, Query[0])==0)//strcmp一个比较字符串是否相同的函数 原型为:int strcmp(char *a, char *b); 若被比较的两个字符串相同则返回0
{
printf("查询结果:%s\n",p[i].name);
printf("课1\t课2\t课3\t课4\t课5\t\n");
printf("%d\t%d\t%d\t%d\t%d\n",p[i].score[0],p[i].score[1],p[i].score[2],p[i].score[3],p[i].score[4]);
break;
}
}
if(i==5)//如果最后i加完也就是四名同学全部查询完还是没有找到说明“查无此人”
{
printf("查无此人");
}
}
void main()
{
struct student stu[N];
input(stu);
danke(stu);
everyone(stu);
seek(stu);
}
//--------------Copy BaiYuQing Stdio--------------//
//-------------------2020-12-16-------------------//